文件,文件夹操作

 
ios开发经常会遇到读文件,写文件等,对文件和文件夹的操作,这时就可以使用NSFileManager,NSFileHandle等类来实现。

下面总结了各种常用的操作:
 
1,遍历一个目录下的所有文件
 //假设用户文档下有如下文件和文件夹[test1.txt,fold1/test2.txt]
 let manager = NSFileManager.defaultManager()
 let urlForDocument = manager.URLsForDirectory( NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let url = urlForDocument[] 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/,
 // file://Users/.../Application/.../Documents/test1.txt])
 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/,
 // file://Users/.../Application/.../Documents/fold1/test2.txt,
 // file://Users/.../Application/.../Documents/test1.txt])
 println("enumeratorAtURL: \(enumeratorAtURL?.allObjects)")

 //(5)深度遍历,会递归遍历子文件夹(包括符号链接,所以要求性能的话用enumeratorAtPath)
 let subPaths = manager.subpathsAtPath(url.path!)
 //subPaths:Optional([fold1, fold1/test2.txt, test1.txt])
 println("subPaths: \(subPaths)")
 

2,判断文件或文件夹是否存在

 
 
let fileManager = NSFileManager.defaultManager()
let filePath:String = NSHomeDirectory() + "/Documents/hangge.txt"
var exist = fileManager.fileExistsAtPath(filePath)

3,创建文件夹

方式1:

 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:

 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[] as NSURL
 var error:NSErrorPointer = nil
 createFolder("folder", baseUrl: url)
 

4,将对象写入文件
可以通过writeToFile方法,可以创建文件并将对象写入,对象包括String,NSString,UIImage,NSArray,NSDictionary等。
(1)把String保存到文件

 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)把图片保存到文件路径下

 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保存到文件路径下

 var array = NSArray(objects: "aaa","bbb","ccc")
 let filePath:String = NSHomeDirectory() + "/Documents/array.plist"
 array.writeToFile(filePath, atomically: true)

(4)把NSDictionary保存到文件路径下

 var dictionary = NSDictionary(objects: ["], forKeys: ["aaa","bbb"])
 let filePath:String = NSHomeDirectory() + "/Documents/dictionary.plist"
 dictionary.writeToFile(filePath, atomically: true)

5,创建文件

 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[] as NSURL
 var error:NSErrorPointer = nil
 createFile("test.txt", fileBaseUrl: url)
 //createFile("folder/new.txt", fileBaseUrl: url)
 

6,复制文件

(1)方法1

 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

 // 定位到用户文档目录
 let manager = NSFileManager.defaultManager()
 let urlForDocument = manager.URLsForDirectory( NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let url = urlForDocument[] 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

 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

 // 定位到用户文档目录
 let manager = NSFileManager.defaultManager()
 let urlForDocument = manager.URLsForDirectory( NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let url = urlForDocument[] 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

 let fileManager = NSFileManager.defaultManager()
 let homeDirectory = NSHomeDirectory()
 var error:NSErrorPointer = nil
 let srcUrl = homeDirectory + "/Documents/hangge.txt"
 fileManager.removeItemAtPath(srcUrl, error: error)

(2)方法2

 // 定位到用户文档目录
 let manager = NSFileManager.defaultManager()
 let urlForDocument = manager.URLsForDirectory( NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let url = urlForDocument[] 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:获取所有文件,然后遍历删除

 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:删除目录后重新创建该目录

 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,读取文件

 let manager = NSFileManager.defaultManager()
 let urlsForDocDirectory = manager.URLsForDirectory(NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let docPath:NSURL = urlsForDocDirectory[] 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,在任意位置写入数据

 let string = "添加一些文字到文件末尾"
 let appendedData = string.dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: true)
 let writeHandler = NSFileHandle(forWritingToURL:file,error:nil)!
 writeHandler.seekToEndOfFile()
 writeHandler.writeData(appendedData!)
 

12,文件权限判断

 let manager = NSFileManager.defaultManager()
 let urlsForDocDirectory = manager.URLsForDirectory(NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let docPath:NSURL = urlsForDocDirectory[] 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,获取文件属性(创建时间,修改时间,文件大小,文件类型等信息)

 let manager = NSFileManager.defaultManager()
 let urlsForDocDirectory = manager.URLsForDirectory(NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let docPath:NSURL = urlsForDocDirectory[] as NSURL
 let file = docPath.URLByAppendingPathComponent("test.txt")

 let attributes = manager.attributesOfItemAtPath(file.path!,error:nil) //结果为AnyObject类型
 println("attributes: \(attributes!)")
 

14,文件/文件夹比较

 let manager = NSFileManager.defaultManager()
 let urlsForDocDirectory = manager.URLsForDirectory(NSSearchPathDirectory.DocumentDirectory, inDomains:NSSearchPathDomainMask.UserDomainMask)
 let docPath:NSURL = urlsForDocDirectory[] as NSURL
 let contents = manager.contentsOfDirectoryAtPath(docPath.path!,error:nil)!

 //下面比较前面两个文件是否内容相同(该方法也可以用来比较目录)
 let count = contents.count
  {
     let path1 = docPath.path! + ] as String)
     let path2 = docPath.path! + ] as String)
     let equal = manager.contentsEqualAtPath(path1,andPath:path2)
     println("比较结果: \(equal)")
 }
 

iOS开发——Swift篇&文件,文件夹操作的更多相关文章

  1. iOS开发Swift篇(02) NSThread线程相关简单说明

    iOS开发Swift篇(02) NSThread线程相关简单说明 一 说明 1)关于多线程部分的理论知识和OC实现,在之前的博文中已经写明,所以这里不再说明. 2)该文仅仅简单讲解NSThread在s ...

  2. iOS开发Swift篇—(九)属性

    iOS开发Swift篇—(九)属性 一.类的定义 Swift与Objective-C定义类的区别 Objective-C:一般需要2个文件,1个.h声明文件和1个.m实现文件 Swift:只需要1个. ...

  3. 李洪强iOS开发Swift篇—09_属性

    李洪强iOS开发Swift篇—09_属性 一.类的定义 Swift与Objective-C定义类的区别 Objective-C:一般需要2个文件,1个.h声明文件和1个.m实现文件 Swift:只需要 ...

  4. iOS开发Swift篇—(三)字符串和数据类型

    iOS开发Swift篇—(三)字符串和数据类型 一.字符串 字符串是String类型的数据,用双引号""包住文字内容  let website = "http://www ...

  5. 李洪强iOS开发Swift篇---12_NSThread线程相关简单说明

    李洪强iOS开发Swift篇---12_NSThread线程相关简单说明 一 说明 1)关于多线程部分的理论知识和OC实现,在之前的博文中已经写明,所以这里不再说明. 2)该文仅仅简单讲解NSThre ...

  6. 李洪强iOS开发Swift篇—03_字符串和数据类型

    李洪强iOS开发Swift篇—03_字符串和数据类型 一.字符串 字符串是String类型的数据,用双引号""包住文字内容  let website = "http:// ...

  7. iOS开发Swift篇—(一)简单介绍

    iOS开发Swift篇—简单介绍 一.简介 Swift是苹果于2014年WWDC(苹果开发者大会)发布的全新编程语言 Swift在天朝译为“雨燕”,是它的LOGO 是一只燕子,跟Objective-C ...

  8. iOS开发Swift篇—(二)变量和常量

    iOS开发Swift篇—(二)变量和常量 一.语言的性能 (1)根据WWDC的展示 在进行复杂对象排序时Objective-C的性能是Python的2.8倍,Swift的性能是Python的3.9倍 ...

  9. iOS开发Swift篇—(四)运算符

    iOS开发Swift篇—(四)运算符 一.运算符 1.Swift所支持的部分运算符有以下一些 赋值运算符:= 复合赋值运算符:+=.-= 算术运算符:+.-.*./ 求余运算符:% 自增.自减运算符: ...

  10. iOS开发Swift篇—(五)元组类型

    iOS开发Swift篇—(五)元组类型 一.元组类型介绍 1.什么是元组类型 元组类型由 N个 任意类型的数据组成(N >= 0),组成元组类型的数据可以称为“元素” 示例: let posit ...

随机推荐

  1. XtraGrid的若干种用法 z

    支持多种类型的数据集合作为数据源 XtraGrid与传统的DataGridView一样,支持多种类型作为其数据源.下面例子是将DataTable, List<T>和数组分别绑定到XtraG ...

  2. 【剑指offer 面试题14】调整数组顺序使奇数位于偶数前面

    思路: 头尾指针,向中间遍历,依据条件交换元素. #include <iostream> using namespace std; void reOrder(int *pData, uns ...

  3. Tableau学习笔记之三

    1.Tableau可以连接多种多样的数据以及数据库,例如txt,xls,mdb,sql server,oracle等等 2.Tableau还可以从剪贴板上粘贴数据 3.维度和度量的理解: 1)维度即表 ...

  4. Python相关书籍推荐

    Python基础教程(第2版 修订版) 作      者 [挪] Magnus Lie Hetland 著:司维,曾军崴,谭颖华 译 出 版 社 人民邮电出版社 出版时间 2014-06-01 版   ...

  5. bzoj 3732 Network(最短路+倍增 | LCT)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3732 [题意] 给定一个无向图,处理若干询问:uv路径上最长的边最小是多少? [思路一 ...

  6. mybatis系列-11-一对多查询

    11.1     需求 查询订单及订单明细的信息. 11.2     sql语句 确定主查询表:订单表 确定关联查询表:订单明细表 在一对一查询基础上添加订单明细表关联即可. SELECT order ...

  7. Android 4.4 音量调节流程分析(二)

    之前在Android 4.4 音量调节流程分析(一)里已经有简单的分析音量控制的流程,今天想接着继续分析下音量大小计算的方法.对于任一播放文件而言其本身都有着固定大小的音量Volume_Max,而在A ...

  8. 深入理解jQuery插件开发(转)

    转自:http://blog.jobbole.com/30550/ 如果你看到这篇文章,我确信你毫无疑问会认为jQuery是一个使用简便的库.jQuery可能使用起来很简单,但是它仍然有一些奇怪的地方 ...

  9. mac搭建PHP开发环境

    在Mac系统上搭建Php服务器环境: LAMP: Linux Apache MySQL PHP MAMP: MACOS APACHE(自带) MYSQL(需自己安装) PHP(自带) 一.APACHE ...

  10. as3 中trace() 函数对效率的影响

    进行页游开发的过程中,很多开发者都有一个习惯,在数据输出中添加trace()函数来跟踪数值 - 不进行条件编译,发布的时候也不删除.实际上大量的trace函数会降低程序的效率,我们可以用一个简单的例子 ...