iOS开发——Swift篇&文件,文件夹操作
文件,文件夹操作
//假设用户文档下有如下文件和文件夹[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,创建文件夹
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,复制文件
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篇&文件,文件夹操作的更多相关文章
- iOS开发Swift篇(02) NSThread线程相关简单说明
iOS开发Swift篇(02) NSThread线程相关简单说明 一 说明 1)关于多线程部分的理论知识和OC实现,在之前的博文中已经写明,所以这里不再说明. 2)该文仅仅简单讲解NSThread在s ...
- iOS开发Swift篇—(九)属性
iOS开发Swift篇—(九)属性 一.类的定义 Swift与Objective-C定义类的区别 Objective-C:一般需要2个文件,1个.h声明文件和1个.m实现文件 Swift:只需要1个. ...
- 李洪强iOS开发Swift篇—09_属性
李洪强iOS开发Swift篇—09_属性 一.类的定义 Swift与Objective-C定义类的区别 Objective-C:一般需要2个文件,1个.h声明文件和1个.m实现文件 Swift:只需要 ...
- iOS开发Swift篇—(三)字符串和数据类型
iOS开发Swift篇—(三)字符串和数据类型 一.字符串 字符串是String类型的数据,用双引号""包住文字内容 let website = "http://www ...
- 李洪强iOS开发Swift篇---12_NSThread线程相关简单说明
李洪强iOS开发Swift篇---12_NSThread线程相关简单说明 一 说明 1)关于多线程部分的理论知识和OC实现,在之前的博文中已经写明,所以这里不再说明. 2)该文仅仅简单讲解NSThre ...
- 李洪强iOS开发Swift篇—03_字符串和数据类型
李洪强iOS开发Swift篇—03_字符串和数据类型 一.字符串 字符串是String类型的数据,用双引号""包住文字内容 let website = "http:// ...
- iOS开发Swift篇—(一)简单介绍
iOS开发Swift篇—简单介绍 一.简介 Swift是苹果于2014年WWDC(苹果开发者大会)发布的全新编程语言 Swift在天朝译为“雨燕”,是它的LOGO 是一只燕子,跟Objective-C ...
- iOS开发Swift篇—(二)变量和常量
iOS开发Swift篇—(二)变量和常量 一.语言的性能 (1)根据WWDC的展示 在进行复杂对象排序时Objective-C的性能是Python的2.8倍,Swift的性能是Python的3.9倍 ...
- iOS开发Swift篇—(四)运算符
iOS开发Swift篇—(四)运算符 一.运算符 1.Swift所支持的部分运算符有以下一些 赋值运算符:= 复合赋值运算符:+=.-= 算术运算符:+.-.*./ 求余运算符:% 自增.自减运算符: ...
- iOS开发Swift篇—(五)元组类型
iOS开发Swift篇—(五)元组类型 一.元组类型介绍 1.什么是元组类型 元组类型由 N个 任意类型的数据组成(N >= 0),组成元组类型的数据可以称为“元素” 示例: let posit ...
随机推荐
- Inxi:获取Linux系统和硬件信息的神器
导读 在这篇文章里,我们将看到如何使用inxi来获取这些详情信息.在论坛技术支持中,它可以作为调试工具,迅速确定用户的系统配置和硬件信息. Inxi是一个可以获取完整的系统和硬件详情信息的命令行工具, ...
- java web 学习十二(session)
一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...
- 【LeetCode 208】Implement Trie (Prefix Tree)
Implement a trie with insert, search, and startsWith methods. Note:You may assume that all inputs ar ...
- <译>Selenium Python Bindings 1 - Installation
Installation Introduction Selenium Python bindings 提供了一个简单的API来使用Selenium WebDriver编写使用功能/验收测试.通过Sel ...
- C++实现网格水印之调试笔记(六)—— 提取完成
昨天在修改了可以调试出来的错误之后,提取出的水印和嵌入的仍然相去甚远.这个时候我觉得有必要整理一下嵌入和提取的整个过程. 嵌入过程: Step1,嵌入的时候对网格的拉普拉斯矩阵L进行特征值分解,得到特 ...
- 45度地图遮挡问题解决方案(cocos2d-x)
最近一直在做45度斜视角游戏,也就是isometric等容地图,俗称2.5D.地图上物体的前后遮挡是我遇到的第一个问题,总结一下处理方法. 遮挡问题(不知道术语),就是比如一个角色站在树后面,那么树要 ...
- 纯css实现扁平化360卫士logo demo
前几天在w3ctech上看到有人用纯css写出了360卫士的logo,感觉蛮好玩的. 因为自己用css以来,还没有写过这种玩意,出于娱乐,我也来试着尝试一下. 开始也不知到怎么下手,最棘手的是那两个像 ...
- 查看linux服务器中的apache是否安装以及安装路径
1.可以通过 apachectl -v 查看apache是否安装,如果安装了的话会显示版本号: 2.如果通过rpm包安装的话可以用 rpm -q httpd 查看,如果安装的的话会显示包的名称
- Emmet:HTML/CSS代码快速编写神器(转)
Emmet的前身是大名鼎鼎的Zen coding,如果你从事Web前端开发的话,对该插件一定不会陌生.它使用仿CSS选择器的语法来生成代码,大大提高了HTML/CSS代码编写的速度,比如下面的演示: ...
- ArcMap10.1无法保存编辑的内容
问题描述:在arcMap10.1中编辑SDE库中要素,保存编辑内容时报错: 无法保存编辑内容.基础DBMS错误[ORA-29877:failed in the execution of the ODC ...