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 NSURLvar 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 NSURLvar error:NSErrorPointer = nilcreateFolder("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 = nilvar 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 NSURLvar error:NSErrorPointer = nilcreateFile("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 = nillet 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 NSURLvar error:NSErrorPointer = nillet 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 = nillet 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 NSURLvar error:NSErrorPointer = nillet 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 = nillet 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 NSURLvar error:NSErrorPointer = nillet 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 = nilvar 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 = nilvar 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 NSURLlet file = docPath.URLByAppendingPathComponent("test.txt")//方法1var readHandler = NSFileHandle(forReadingFromURL:file,error:nil)!var data = readHandler.readDataToEndOfFile()var readString = NSString(data: data, encoding: NSUTF8StringEncoding)println("文件内容: \(readString)")//方法2let 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 NSURLlet 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 NSURLlet 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 NSURLlet contents = manager.contentsOfDirectoryAtPath(docPath.path!,error:nil)!//下面比较前面两个文件是否内容相同(该方法也可以用来比较目录)let count = contents.countif 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 ...
随机推荐
- Qt学习之路(49): 通用算法
今天开始的部分是关于Qt提供的一些通用算法.这部分内容来自C++ GUI Programming with Qt 4, 2nd Edition. <QtAlgorithms>提供了一系 ...
- 转:携程App的网络性能优化实践
http://kb.cnblogs.com/page/519824/ 携程App的网络性能优化实践 受益匪浅的一篇文章,让我知道网络交互并不是简单的传输和接受数据.真正的难点在于后面的性能优化 下面对 ...
- JS 2016-09-30T22:04:27.5220743+08:00 转换为日期
1.转换代码 new Date(item.CreatedDate).Format("yyyy-MM-dd hh:mm") 2.需要拓展的方法 // 对Date的扩展,将 Date ...
- 京东金融集团BD部门招聘 BD经理
新标签页http://74.55.154.136/ 互联网招聘_cnBeta.COM 北京 / 全职 / 20k-30k / 经验3-5年 / 本科及以上 / 1天前发布 职位诱惑 : 五险一金 职位 ...
- BZOJ 2693: jzptab( 莫比乌斯反演 )
速度居然#2...目测是因为我没用long long.. 求∑ lcm(i, j) (1 <= i <= n, 1 <= j <= m) 化简之后就只须求f(x) = x∑u( ...
- WCF技术剖析之十一:异步操作在WCF中的应用(上篇)
原文:WCF技术剖析之十一:异步操作在WCF中的应用(上篇) 按照操作执行所需的资源类型,我们可以将操作分为CPU绑定型(CPU Bound)操作和I/O绑定型(I/O Bound)操作.对于前者,操 ...
- 基于visual Studio2013解决C语言竞赛题之1011对称
题目 解决代码及点评 /* 11. 判断一个给定的5×5方阵是否以第3列为轴线对称? */ #include <stdio.h> #include <s ...
- boost uuid
uuid: uuid库是一个小的使用工具,可以表示和生成UUID UUID是University Unique Identifier的缩写,它是一个128位的数字(16字节),不需要有一个中央认证机构 ...
- 在jsp页面下, 让eclipse完全支持HTML/JS/CSS智能提示(转)
我们平时用eclipse开发jsp页面时智能提示效果不太理想,今天用了两个小时发现了eclipse也可以像Visual Studio 2008那样完全智能提示HTML/JS/CSS代码,使用ecl ...
- 图片组件——axure线框图部件库介绍
我们在后面的组件使用中,都统一使用"从部件区域拖拽图片组件到页面区域中" 1. 图片载入 1.1 将图片组件拖拽到页面区域 1.2 双击图片组件 1.3 选择合适图片,点击打开 1 ...