Swift - 文件,文件夹操作大全
ios开发经常会遇到读文件,写文件等,对文件和文件夹的操作,这时就可以使用NSFileManager,NSFileHandle等类来实现。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
//假设用户文档下有如下文件和文件夹[test1.txt,fold1/test2.txt] let manager = NSFileManager .defaultManager() let urlForDocument = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let url = urlForDocument[0] as NSURL var error: NSErrorPointer = nil //(1)对指定路径执行浅搜索,返回指定目录路径下的文件、子目录及符号链接的列表 let contentsOfPath = manager.contentsOfDirectoryAtPath(url.path!, error: error) //contentsOfPath:Optional([fold1, test1.txt]) println ( "contentsOfPath: \(contentsOfPath)" ) //(2)类似上面的,对指定路径执行浅搜索,返回指定目录路径下的文件、子目录及符号链接的列表 let contentsOfURL = manager.contentsOfDirectoryAtURL(url, includingPropertiesForKeys: nil , options: NSDirectoryEnumerationOptions . SkipsHiddenFiles , error: error); //contentsOfURL:Optional([file://Users/.../Application/.../Documents/fold1/, println ( "contentsOfURL: \(contentsOfURL)" ) //(3)深度遍历,会递归遍历子文件夹(但不会递归符号链接) let enumeratorAtPath = manager.enumeratorAtPath(url.path!) //enumeratorAtPath:Optional([fold1, fold1/test2.txt, test1.txt]) println ( "enumeratorAtPath: \(enumeratorAtPath?.allObjects)" ) //(4)类似上面的,深度遍历,会递归遍历子文件夹(但不会递归符号链接) let enumeratorAtURL = manager.enumeratorAtURL(url, includingPropertiesForKeys: nil , options: NSDirectoryEnumerationOptions . SkipsHiddenFiles , errorHandler: nil ) //contentsOfURL:Optional([file://Users/.../Application/.../Documents/fold1/, println ( "enumeratorAtURL: \(enumeratorAtURL?.allObjects)" ) //(5)深度遍历,会递归遍历子文件夹(包括符号链接,所以要求性能的话用enumeratorAtPath) let subPaths = manager.subpathsAtPath(url.path!) //subPaths:Optional([fold1, fold1/test2.txt, test1.txt]) println ( "subPaths: \(subPaths)" ) |
2,判断文件或文件夹是否存在
1
2
3
|
let fileManager = NSFileManager .defaultManager() let filePath: String = NSHomeDirectory () + "/Documents/hangge.txt" var exist = fileManager.fileExistsAtPath(filePath) |
3,创建文件夹
1
2
3
4
5
6
|
let myDirectory: String = NSHomeDirectory () + "/Documents/myFolder/Files" let fileManager = NSFileManager .defaultManager() var error: NSErrorPointer = nil //withIntermediateDirectories为ture表示路径中间如果有不存在的文件夹都会创建 var isSuccess: Bool = fileManager.createDirectoryAtPath(myDirectory, withIntermediateDirectories: true , attributes: nil , error: error) |
方式2:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
func createFolder(name: String ,baseUrl: NSURL ){ let manager = NSFileManager .defaultManager() var error: NSErrorPointer = nil let folder = baseUrl. URLByAppendingPathComponent (name, isDirectory: true ) println ( "文件夹: \(folder)" ) let exist = manager.fileExistsAtPath(folder.path!) if !exist { let createSuccess = manager.createDirectoryAtURL(folder, withIntermediateDirectories: true , attributes: nil , error: error) println ( "文件夹创建结果: \(createSuccess)" ) } } //在文档目录下新建folder目录 let manager = NSFileManager .defaultManager() let urlForDocument = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let url = urlForDocument[0] as NSURL var error: NSErrorPointer = nil createFolder( "folder" , baseUrl: url) |
4,将对象写入文件
可以通过writeToFile方法,可以创建文件并将对象写入,对象包括String,NSString,UIImage,NSArray,NSDictionary等。
(1)把String保存到文件
1
2
3
4
|
let filePath: String = NSHomeDirectory () + "/Documents/hangge.txt" var error: NSErrorPointer = nil var info = "欢迎来到hange.com" info.writeToFile(filePath, atomically: true , encoding: NSUTF8StringEncoding , error: error) |
(2)把图片保存到文件路径下
1
2
3
4
|
let filePath: String = NSHomeDirectory () + "/Documents/hangge.png" var image = UIImage (named: "apple.png" ) var data: NSData = UIImagePNGRepresentation (image) data.writeToFile(filePath, atomically: true ) |
(3)把NSArray保存到文件路径下
1
2
3
|
var array = NSArray (objects: "aaa" , "bbb" , "ccc" ) let filePath: String = NSHomeDirectory () + "/Documents/array.plist" array.writeToFile(filePath, atomically: true ) |
(4)把NSDictionary保存到文件路径下
1
2
3
|
var dictionary = NSDictionary (objects: [ "111" , "222" ], forKeys: [ "aaa" , "bbb" ]) let filePath: String = NSHomeDirectory () + "/Documents/dictionary.plist" dictionary.writeToFile(filePath, atomically: true ) |
5,创建文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
func createFile(name: String ,fileBaseUrl: NSURL ){ let manager = NSFileManager .defaultManager() var error: NSErrorPointer = nil let file = fileBaseUrl. URLByAppendingPathComponent (name) println ( "文件: \(file)" ) let exist = manager.fileExistsAtPath(file.path!) if !exist { let data = NSData (base64EncodedString: "aGVsbG8gd29ybGQ=" ,options:. IgnoreUnknownCharacters ) let createSuccess = manager.createFileAtPath(file.path!,contents:data,attributes: nil ) println ( "文件创建结果: \(createSuccess)" ) } } //在文档目录下新建test.txt文件 let manager = NSFileManager .defaultManager() let urlForDocument = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let url = urlForDocument[0] as NSURL var error: NSErrorPointer = nil createFile( "test.txt" , fileBaseUrl: url) //createFile("folder/new.txt", fileBaseUrl: url) |
6,复制文件
(1)方法1
1
2
3
4
5
6
|
let fileManager = NSFileManager .defaultManager() let homeDirectory = NSHomeDirectory () var error: NSErrorPointer = nil let srcUrl = homeDirectory + "/Documents/hangge.txt" let toUrl = homeDirectory + "/Documents/copyed.txt" fileManager.copyItemAtPath(srcUrl, toPath: toUrl, error: error) |
(2)方法2
1
2
3
4
5
6
7
8
9
10
11
12
13
|
// 定位到用户文档目录 let manager = NSFileManager .defaultManager() let urlForDocument = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let url = urlForDocument[0] as NSURL var error: NSErrorPointer = nil let contentsOfURL = manager.contentsOfDirectoryAtURL(url, includingPropertiesForKeys: nil , options: NSDirectoryEnumerationOptions . SkipsHiddenFiles , error: error); // 将test.txt文件拷贝到文档目录根目录下的copyed.txt文件 let srcUrl = url. URLByAppendingPathComponent ( "test.txt" ) let toUrl = url. URLByAppendingPathComponent ( "copyed.txt" ) let copyItemSuccess = manager.copyItemAtURL(srcUrl, toURL: toUrl, error: error) println ( "复制结果: \(copyItemSuccess)" ) |
7,移动文件
(1)方法1
1
2
3
4
5
6
|
let fileManager = NSFileManager .defaultManager() let homeDirectory = NSHomeDirectory () var error: NSErrorPointer = nil let srcUrl = homeDirectory + "/Documents/hangge.txt" let toUrl = homeDirectory + "/Documents/moved" fileManager.moveItemAtPath(srcUrl, toPath: toUrl, error: error) |
(2)方法2
1
2
3
4
5
6
7
8
9
10
11
|
// 定位到用户文档目录 let manager = NSFileManager .defaultManager() let urlForDocument = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let url = urlForDocument[0] as NSURL var error: NSErrorPointer = nil let contentsOfURL = manager.contentsOfDirectoryAtURL(url, includingPropertiesForKeys: nil , options: NSDirectoryEnumerationOptions . SkipsHiddenFiles , error: error); let srcUrl = url. URLByAppendingPathComponent ( "test.txt" ) let toUrl = url. URLByAppendingPathComponent ( "copyed.txt" ) // 移动srcUrl中的文件(test.txt)到toUrl中(copyed.txt) let moveItemSuccess = manager.moveItemAtURL(srcUrl, toURL: toUrl, error: error) |
8,删除文件
(1)方法1
1
2
3
4
5
|
let fileManager = NSFileManager .defaultManager() let homeDirectory = NSHomeDirectory () var error: NSErrorPointer = nil let srcUrl = homeDirectory + "/Documents/hangge.txt" fileManager.removeItemAtPath(srcUrl, error: error) |
(2)方法2
1
2
3
4
5
6
7
8
9
10
11
|
// 定位到用户文档目录 let manager = NSFileManager .defaultManager() let urlForDocument = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let url = urlForDocument[0] as NSURL var error: NSErrorPointer = nil let contentsOfURL = manager.contentsOfDirectoryAtURL(url, includingPropertiesForKeys: nil , options: NSDirectoryEnumerationOptions . SkipsHiddenFiles , error: error); let toUrl = url. URLByAppendingPathComponent ( "copyed.txt" ) // 删除文档根目录下的toUrl路径的文件(copyed.txt文件) let removeItemSuccess = manager.removeItemAtURL(toUrl, error: error) println ( "删除结果: \(removeItemSuccess)" ) |
9,删除目录下所有的文件
(1)方法1:获取所有文件,然后遍历删除
1
2
3
4
5
6
7
|
let fileManager = NSFileManager .defaultManager() var error: NSErrorPointer = nil var myDirectory = NSHomeDirectory () + "/Documents/Files" var fileArray:[ AnyObject ]? = fileManager.subpathsAtPath(myDirectory) for fn in fileArray!{ fileManager.removeItemAtPath(myDirectory + "/\(fn)" , error: error) } |
(2)方法2:删除目录后重新创建该目录
1
2
3
4
5
6
|
let fileManager = NSFileManager .defaultManager() var error: NSErrorPointer = nil var myDirectory = NSHomeDirectory () + "/Documents/Files" fileManager.removeItemAtPath(myDirectory, error: error) fileManager.createDirectoryAtPath(myDirectory, withIntermediateDirectories: true , attributes: nil , error: error) |
10,读取文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
let manager = NSFileManager .defaultManager() let urlsForDocDirectory = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let docPath: NSURL = urlsForDocDirectory[0] as NSURL let file = docPath. URLByAppendingPathComponent ( "test.txt" ) //方法1 var readHandler = NSFileHandle (forReadingFromURL:file,error: nil )! var data = readHandler.readDataToEndOfFile() var readString = NSString (data: data, encoding: NSUTF8StringEncoding ) println ( "文件内容: \(readString)" ) //方法2 let data = manager.contentsAtPath(file.path!) var readString = NSString (data: data, encoding: NSUTF8StringEncoding ) println ( "文件内容: \(readString)" ) |
11,在任意位置写入数据
1
2
3
4
5
|
let string = "添加一些文字到文件末尾" let appendedData = string.dataUsingEncoding( NSUTF8StringEncoding , allowLossyConversion: true ) let writeHandler = NSFileHandle (forWritingToURL:file,error: nil )! writeHandler.seekToEndOfFile() writeHandler.writeData(appendedData!) |
12,文件权限判断
1
2
3
4
5
6
7
8
9
10
11
12
13
|
let manager = NSFileManager .defaultManager() let urlsForDocDirectory = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let docPath: NSURL = urlsForDocDirectory[0] as NSURL let file = docPath. URLByAppendingPathComponent ( "test.txt" ) let readable = manager.isReadableFileAtPath(file.path!) println ( "可读: \(readable)" ) let writeable = manager.isWritableFileAtPath(file.path!) println ( "可写: \(writeable)" ) let executable = manager.isExecutableFileAtPath(file.path!) println ( "可执行: \(executable)" ) let deleteable = manager.isDeletableFileAtPath(file.path!) println ( "可删除: \(deleteable)" ) |
13,获取文件属性(创建时间,修改时间,文件大小,文件类型等信息)
1
2
3
4
5
6
7
|
let manager = NSFileManager .defaultManager() let urlsForDocDirectory = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let docPath: NSURL = urlsForDocDirectory[0] as NSURL let file = docPath. URLByAppendingPathComponent ( "test.txt" ) let attributes = manager.attributesOfItemAtPath(file.path!,error: nil ) //结果为AnyObject类型 println ( "attributes: \(attributes!)" ) |
14,文件/文件夹比较
1
2
3
4
5
6
7
8
9
10
11
12
13
|
let manager = NSFileManager .defaultManager() let urlsForDocDirectory = manager. URLsForDirectory ( NSSearchPathDirectory . DocumentDirectory , inDomains: NSSearchPathDomainMask . UserDomainMask ) let docPath: NSURL = urlsForDocDirectory[0] as NSURL let contents = manager.contentsOfDirectoryAtPath(docPath.path!,error: nil )! //下面比较前面两个文件是否内容相同(该方法也可以用来比较目录) let count = contents.count if count > 1 { let path1 = docPath.path! + "/" + (contents[0] as String ) let path2 = docPath.path! + "/" + (contents[1] as String ) let equal = manager.contentsEqualAtPath(path1,andPath:path2) println ( "比较结果: \(equal)" ) } |
Swift - 文件,文件夹操作大全的更多相关文章
- iOS开发——Swift篇&文件,文件夹操作
文件,文件夹操作 ios开发经常会遇到读文件,写文件等,对文件和文件夹的操作,这时就可以使用NSFileManager,NSFileHandle等类来实现. 下面总结了各种常用的操作: 1,遍 ...
- Python文件操作大全,随机删除文件夹内的任意文件
在读文件的时候往往需要遍历文件夹,python的os.path包含了很多文件.文件夹操作的方法: os.path.abspath(path) #返回绝对路径os.path.basename(path ...
- Java 文件操作大全
Java 文件操作大全 //1.创建文件夹 //import java.io.*; File myFolderPath = new File(str1); try { if (!myFolderPat ...
- python文件、文件夹操作OS模块
转自:python文件.文件夹操作OS模块 '''一.python中对文件.文件夹操作时经常用到的os模块和shutil模块常用方法.1.得到当前工作目录,即当前Python脚本工作的目录路径: ...
- 【整理】C#文件操作大全(SamWang)
[整理]C#文件操作大全(SamWang) 文件与文件夹操作主要用到以下几个类: 1.File类: 提供用于创建.复制.删除.移动和打开文件的静态方法,并协助创建 FileStream 对象. msd ...
- 【转】C#添加修改删除文件文件夹大全
[转]C#添加修改删除文件文件夹大全 C#添加修改删除文件文件夹大全 StreamWriter sw = File.AppendText(Server.MapPath(".")+& ...
- [No000083]文件与文件夹操作
#region Folder option 文件夹操作 /// <summary> /// 指定目录是否存在 /// </summary> /// <param name ...
- PHP 文件夹操作「复制、删除、查看大小」递归实现
PHP虽然提供了 filesize.copy.unlink 等文件操作的函数,但是没有提供 dirsize.copydir.rmdirs 等文件夹操作的函数(rmdir也只能删除空目录).所以只能手动 ...
- 【整理】C#文件操作大全(SamWang)<转>
文件与文件夹操作主要用到以下几个类: 1.File类: 提供用于创建.复制.删除.移动和打开文件的静态方法,并协助创建 FileStream 对象. msdn:http://msdn.microsof ...
随机推荐
- BZOJ 4057: [Cerc2012]Kingdoms( 状压dp )
状压dp.... 我已开始用递归结果就 TLE 了... 不科学啊...我dp基本上都是用递归的..我只好改成递推 , 刷表法 将全部公司用二进制表示 , 压成一个数 . 0 表示破产 , 1 表示没 ...
- [转]使用xftp连接centos6.5
首先要在windows上安装xftp软件,这个是傻瓜式操作就不说了 安装完成之后,在centos上查看是否装了xftpd服务,[root@centos Desktop]# rpm -qa | grep ...
- Java --CountDownLatch简介
CountDownLatch 1.类介绍 一个同步辅助类,在完成一组正在其他线程中执行的操作之前,它允许一个或多个线程一直等待.用给定的计数 初始化 CountDownLatch.由于调用了 coun ...
- 转:git windows中文 乱码问题解决汇总
it的Windows版本Msysgit对中文的支持不够好 .当使用时,会出现以下三种情况的中文乱码: 下面的几个文件都在git安装目录下文件夹etc内.1.ls不能显示中文目录 解决办法:在git/g ...
- OGR API Tutorial
This document is intended to document using the OGR C++ classes to read and write data from a file. ...
- spring利用扫描方式对bean的处理(对任何版本如何获取xml配置信息的处理)
利用扫描的方式将组件注入容器,就也可以不用操作bean来实例化对象了. 下面我做一个例子 我用的spring3.2.2版本的 首先写一个spring.xml. <?xml version=&qu ...
- Windows下sass的安装
sass依赖Ruby,所以,首先得先安装个Ruby 安装步骤: 1.安装Ruby的时候,勾上Add Ruby executables to your PATH(添加环境变量) 2.安装好Ruby之后, ...
- PHP - 点击更换头像
原理: 操作流程: 首先点击头像图片,弹出选择窗口,选中其中一个则窗口推出头像更换. 效果: 主页面代码: <tr> <td>头像:</td> <td> ...
- Cocos2dx系列笔记7:一个简单的跑酷游戏《萝莉快跑》的消化(附下载)
懒骨头(http://blog.csdn.com/iamlazybone) 或许有天 我们羡慕和崇拜的人 因为我们的努力 也会来了解我们 说不定 还会成为好友 骨头喜欢这样与哲哲共勉 多少个夜晚 一张 ...
- Eclipse用法和技巧十三:自动生成的TODO注释1
使用eclipse的快捷键自动生成的代码,经常有这样的注释. 一眼看上去这个注释和一般的注释并无什么差别,不过TODO这个字符串的颜色不一样,应该有些内容.TODO是eclipse中提供的一种任务标签 ...