
在objc中已经有KSfileUtilitIEs的ks_stringRelativeToURL方法,非常接近.我正在寻找可以在linux上运行的纯粹快速解决方案.
我更喜欢使用file:// URL的解决方案,但String也没问题.
文件系统可以区分大小写/不区分大小写.确定相对路径可能很棘手.
输入和预期输出的示例:
| Long Path | relative to Path | Return Value ||--------------------------------|------------------|-------------------|| /usr/X11/agent/47.gz | /usr/X11 | agent/47.gz || /usr/share/man/meltdown.1 | /usr/share/cups | ../man/meltdown.1 || file:///var/logs/x/y/z/log.txt | file:///var/logs | x/y/z/log.txt |
Swift已经拥有FileManager.getRelationship(_:of:in:toItemAt:),但它没有返回相对路径.
解决方法 Swift标准库或者没有这样的方法据我所知,基金会框架.
以下是作为URL的扩展方法的可能实现:
extension URL { func relativePath(from base: URL) -> String? { // Ensure that both URLs represent files: guard self.isfileURL && base.isfileURL else { return nil } // Remove/replace "." and "..",make paths absolute: let destComponents = self.standardized.pathComponents let baseComponents = base.standardized.pathComponents // Find number of common path components: var i = 0 while i < destComponents.count && i < baseComponents.count && destComponents[i] == baseComponents[i] { i += 1 } // Build relative path: var relComponents = Array(repeating: "..",count: baseComponents.count - i) relComponents.append(contentsOf: destComponents[i...]) return relComponents.joined(separator: "/") }} 我的测试代码:
func test(_ p1: String,_ p2: String) { let u1 = URL(fileURLWithPath: p1) let u2 = URL(fileURLWithPath: p2) print(u1.relativePath(from: u2) ?? "<ERROR>")}test("/usr/X11/agent/47.gz","/usr/X11") // "agent/47.gz"test("/usr/share/man/meltdown.1","/usr/share/cups") // "../man/meltdown.1"test("/var/logs/x/y/z/log.txt","/var/logs") // "x/y/z/log.txt" 备注:
>“.”并删除给定URL中的“..”和相对文件URL
是绝对的(都使用URL的标准化方法).
>不处理案例(in)敏感度.
>假设基本URL表示目录.
附录:@neoneye将其包装成Swift包:
SwiftyRelativePath.
以上是内存溢出为你收集整理的Swift相当于Ruby的“Pathname.relative_path_from”全部内容,希望文章能够帮你解决Swift相当于Ruby的“Pathname.relative_path_from”所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)