在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
Swift3.0语言教程使用路径字符串Swift3.0语言教程使用路径字符串,路径其实是字符串的一种,我们称为路径字符串。本小节将讲解如何使用路径字符串。 1.组合路径 开发者可以将数组快速的组合成一个路径,此功能的实现可以使用NSString中的path(withComponents:)方法,其语法形式如下: class func path(withComponents components: [String]) -> String 其中,components是一个字符串数组。 【示例1-80】以下将数组组合为路径。 import Foundation let components:[String]=["Users","mac","Desktop","File.txt"] let path=NSString.path(withComponents: components) //组合路径 print(path) 运行结果如下: Users/mac/Desktop/File.txt 2.分割路径 在NSString中有组合路径相对的就有分割路径,使用pathComponents属性就可以实现此功能,其语法形式如下: var pathComponents: [String] { get } 【示例1-81】以下将实现路径的分割。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print(path.pathComponents) //分割路径 运行结果如下: ["/", "Users", "mac", "Desktop", "File.txt"] 3.获取路径信息 当一个路径很长的时候,我们要获取路径的一些内容就会变得非常困难,在NSString中提供了很多的属性为我们讲解了这一难题。 (1)lastPathComponent属性可以获取路径的最后一部分内容(即文件名),其语法形式如下: var lastPathComponent: String { get } 【示例1-82】以下将获取路径的最后一部分内容。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print(path.lastPathComponent) //获取路径的最后一部分内容 运行结果如下: File.txt (2)pathExtension属性可以获取路径的扩展名,其语法形式如下: var pathExtension: String { get } 【示例1-83】以下将获取路径的扩展名。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print(path.pathExtension) 运行结果如下: txt (3)isAbsolutePath属性可以用来判断路径是否为绝对路径,其语法形式如下: var isAbsolutePath: Bool { get } 【示例1-84】以下将判断路径是否为绝对路径。 import Foundation var path1=NSString(string:"/Users/mac/Desktop/File.txt") var path2=NSString(string:"mac/Desktop/File.txt") //判断路径path1是否为绝对路径 if(path1.isAbsolutePath){ print("path1是绝对路径") }else{ print("path1不是绝对路径") } //判断路径path2是否为绝对路径 if(path2.isAbsolutePath){ print("path2是绝对路径") }else{ print("path2不是绝对路径") } 运行结果如下: path1是绝对路径 path2不是绝对路径 4.将路径字符串转换为C字符串 路径字符串也是可以转换为C字符串的,此功能的实现需要使用到fileSystemRepresentation属性。该属性首先将这个路径转换成文件系统的规范形式,然后用UTF-8编码形成C字符串,其语法形式如下: var fileSystemRepresentation: UnsafePointer<Int8> { get } 【示例1-85】以下将路径字符串转换为C字符串。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") var str1="%s" var systemRepresentation=path.fileSystemRepresentation //转换 var str2=NSString(format: str1,systemRepresentation) print(str2) 运行结果如下: /Users/mac/Desktop/File.txt 5.简化路径 简化路径其实就是将系统的主目录替换为“~”,此功能的实现需要使用到abbreviatingWithTildeInPath属性,其语法形式如下: var abbreviatingWithTildeInPath: String { get } 【示例1-86】以下将简化路径。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print(path.abbreviatingWithTildeInPath) //简化路径 运行结果如下: ~/Desktop/File.txt 6.扩展路径 在NSString中有简化路径的方法,相对的就会有扩展路径的方法,此功能需要使用expandingTildeInPath属性,该属性可以将“~”替换为系统的主目录,其语法形式如下: var deletingPathExtension: String { get } 【示例1-87】以下将扩展路径 import Foundation var path=NSString(string:"~/Desktop/File.txt") print(path.expandingTildeInPath) //扩展路径 运行结果如下: /Users/mac/Desktop/File.txt 7.追加路径 开发中可以在路径后面追加路径,如果想要实现此功能,可以使用NSString中的appendingPathComponent(_:)、appendingPathExtension(_:)和strings(byAppendingPaths:)方法。 (1)appendingPathComponent(_:)方法可以在路径后面追加一个新的路径,这个路径是一个字符串,其语法形式如下: func appendingPathExtension(_ str: String) -> String? 其中,str用来指定一个字符串。 【示例1-88】以下将使用appendingPathComponent(_:)方法追加一个路径。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print("追加路径前:\(path)") print("追加路径后:\(path.appendingPathComponent("Plist.plist"))") 运行结果如下: 追加路径前:/Users/mac/Desktop/File.txt 追加路径后:/Users/mac/Desktop/File.txt/Plist.plist (2)appendingPathExtension(_:)方法和appendingPathComponent(_:)方法类似,但是appendingPathExtension(_:)在路径后面追加的新路径是一个扩展名。其语法形式如下: 【示例1-89】以下将使用appendingPathExtension(_:)方法追加一个路径。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File") print("追加路径前:\(path)") print("追加路径后:\(path.appendingPathExtension("txt")!)") 运行结果如下: 追加路径前:/Users/mac/Desktop/File 追加路径后:/Users/mac/Desktop/File.txt (3)appendingPathComponent(_:)和appendingPathExtension(_:)方法都是追加一个路径,而strings(byAppendingPaths:)方法是追加多个路径,其语法形式如下: func strings(byAppendingPaths paths: [String]) -> [String] 其中,paths用来指定一个字符串数组。 【示例1-90】以下将使用strings(byAppendingPaths:)方法实现路径的追加。 import Foundation let components:[String]=["File1.txt","File2.txt","File3.txt","File4.txt"] var path=NSString(string:"/Users/mac/Desktop/") var paths=path.strings(byAppendingPaths: components) //遍历 for i in paths{ print(i) } 运行结果如下: /Users/mac/Desktop/File1.txt /Users/mac/Desktop/File2.txt /Users/mac/Desktop/File3.txt /Users/mac/Desktop/File4.txt 8.删除路径 开发者可以在路径中追加路径,也可以删除路径,在NSString中删除路径的属性有2个,分别为deletingLastPathComponent属性和deletingPathExtension属性。 (1)deletingLastPathComponent属性可以用来删除路径中的最后一部分内容,其语法形式如下: var deletingLastPathComponent: String { get } 【示例1-91】以下将使用deletingLastPathComponent属性删除路径的最后一部分内容。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print("删除路径前:\(path)") print("删除路径后:\(path.deletingLastPathComponent)") //删除路径的最后一部分内容 运行结果如下: 删除路径前:/Users/mac/Desktop/File.txt 删除路径后:/Users/mac/Desktop (2)deletingPathExtension属性可以删除路径的扩展名,其语法形式如下: var deletingPathExtension: String { get } 【示例1-92】以下将使用deletingPathExtension属性删除路径的扩展名。 import Foundation var path=NSString(string:"/Users/mac/Desktop/File.txt") print("删除路径前:\(path)") print("删除路径后:\(path.deletingPathExtension)") //删除路径的扩展名 运行结果如下: 删除路径前:/Users/mac/Desktop/File.txt 删除路径后:/Users/mac/Desktop/File 9.解析路径中的符号链接 在大多数的路径中都会存在很多的符号路径,使得路径变的很不规范。在NSString中的resolvingSymlinksInPath属性将解析路径中的符号路径,将不规范的路径变的规范,其语法形式如下: var resolvingSymlinksInPath: String { get } 【示例1-93】以下将解析路径中的符号链接。 import Foundation var path=NSString(string:"/.//tmp/ABC/..") print(path.resolvingSymlinksInPath) //解析路径中的符号链接 运行结果如下: /tmp 10.标准化路径 在NSString中的standardizingPath属性可以移除在路径中无关的部分,从而实现对路径的标准化,其语法形式如下: var standardizingPath: String { get } 【示例1-94】以下将标准化路径。 import Foundation var path=NSString(string:"~/Desktop/File.txt/./tmp") print(path.standardizingPath) //标准化路径 运行结果如下: /Users/mac/Desktop/File.txt/tmp 11.查询文件夹下包含指定扩展名的文件路径 为了快速从文件夹中提取特定类型的文件,NSString提供了completePath(into:caseSensitive:matchesInto:filterTypes:)方法,其语法形式如下: func completePath(into outputName: AutoreleasingUnsafeMutablePointer<NSString?>?, caseSensitive flag: Bool, matchesInto outputArray: AutoreleasingUnsafeMutablePointer<NSArray?>?, filterTypes: [String]?) -> Int 其中,参数说明如下: q outputName:用来指定一个NSString类型的变量指针。 q flag:用来指定是否区分大小写。 q outputArray:用来指定一个NSArray类型的变量指针,其中包含了所有匹配的文件名程序。 q filterTypes:用来指定一个字符串数组,此数组中包含了用来查询的文件扩展名。 【示例1-95】以下将在文件夹NSString中查询扩展名为txt、csv的路径。 import Foundation var partialPath : NSString = "/Users/mac/Desktop/NSString/" var longestCompletition : NSString? var outputArray : NSArray? = [] var filterTypes = ["txt", "csv"] var allMatches = partialPath.completePath(into: &longestCompletition, caseSensitive: false, matchesInto: &outputArray, filterTypes: filterTypes) //查询 print(outputArray!) 运行结果如下: ( "/Users/mac/Desktop/NSString/.git", "/Users/mac/Desktop/NSString/Build", "/Users/mac/Desktop/NSString/File.txt", "/Users/mac/Desktop/NSString/NSString", "/.DocumentRevisions-V100", …… "/Users", "/usr", "/var", "/Volumes" ) Swift3.0语言教程使用路径字符串 |
请发表评论