转载自:http://www.coloroud.com/2015/06/01/Swift-File-Manager/

开头

看来Swift这趟浑水是非干不可,既然如此,那索性就来的彻底吧,来一次全方位,深入的学习之旅。

进入正题,在Swift开发中,几乎是每一个App都需要在本地存储一些本地的持久化数据,毕竟不可能每次App使用都从网上现传数据回来使用吧,那样App的体验将会大打折扣。

ios存储特性

在ios体系中,每个app都是独立的,遵循沙盒机制,app之间数据相互隔离,换个更通俗易懂的说法,你可以把每个App看成是一个用户,就像在Linux系统中,每个用户有一个独立的home目录,该用户只对他的用户目录具有各项操作权。一般来所,程序之间是不可以相互访问的。

目录结构

Apple自ios8以后,app目录结构发生了一些变化,ios8以前按App的Bundle(程序包)和app其他目录放在一起,ios8以后,Bundle被独立起来,和其他的Bundle放在一起,app目录文件相关的数据文件放在一起。

file://~/Library/Developer/CoreSimulator/Devices/模拟器编号/data/Containers/Bundle/Application/app目录对应的目录编号
file://~/Library/Developer/CoreSimulator/Devices/模拟器编号/data/Containers/Data/Application/app目录对应的目录编号
// 注:上面‘~/‘指的是你的用户主目录,比如我的是:/Users/anoxia,而Library/Developer/CoreSimulator/ 是模拟器地址。

当我创建完App,会在沙盒中创建三个文件夹:Document,Library,tmp。

Document:用来存放一些应用持久化数据,可以进行一下文件或文件夹的创建,移动和删除等操作。iTunes备份和恢复时,会包含此目录。

Library:应用一些设置信息及其他状态信息存放于此。

tmp:临时文件存放的目录,当ios重启时,会清空里面的数据。

获取各目录路径

Bundle目录相关操作:

获取应用Bundel包路径:
var bundlePath = NSBundle.mainBundle().bundlePath       // 包路径
println(bunlePath)
获取Bundel资源路径:
var resourcePath = NSBundle.mainBundle().resourcePath     // 资源路径
println(resourcePath)
获取应用可执行文件路径
var executablePath = NSBundle.mainBundle().executablePath // App可执行文件路径
println(executablePath)
在Bundel路径中搜索文件
var infoPlistPath = NSBundle.mainBundle().URLForResource("Info", withExtension: "plist")
println(infoPlistPath)

获取应用根目录:

var homePath = NSHomeDirectory()
println(homePath)

获取Document目录:

var documentPath = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.DocumentDirectory, NSSearchPathDomainMask.UserDomainMask, true)
println(documentPath.last)

获取Library目录

var libraryPath = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.LibraryDirectory, NSSearchPathDomainMask.UserDomainMask, true)
println(libraryPath.last)

获取Library下Caches

var cachePath = NSSearchPathForDirectoriesInDomains(NSSearchPathDirectory.CachesDirectory, NSSearchPathDomainMask.UserDomainMask, true)
println(cachePath.last)

获取tmp

var tmpPath = NSTemporaryDirectory()
println(tmpPath)

NSData

NSString与NSData互转

NSString转NSData
var conversionString = "is a string"
conversionString.dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: true)
println(converedData)
// 输出:NSData(Optional):Optional(<69732061 20737472 696e67>)
NSData转NSString
var converbackString = NSString(data: converedData!, encoding: NSUTF8StringEncoding)
println(converbackString)
// 输出:NSString(Optional):Optional(is a string)
UIImage转NSData
let image = documentDir + "/bg.jpg"
let imageData: NSData = UIImageJPEGRepresentation(UIImage(named: image), 0.1)

从沙盒加载NSData类型的UIImage

// 加载NSData
let imagetest = fileManager.contentsAtPath(imagePath)
println(imagetest)
// 显示
let imageView = UIImageView(frame: view.bounds)
imageView.image = UIImage(named: imagePath)
view.addSubview(imageView)

NSFileManager文件管理

var fileManager = NSFileManager.defaultManager()

创建

文件夹
var documents = NSHomeDirectory() + "/Documents"
var dirPath = documents + "/a/b/c" fileManager.createDirectoryAtPath(dirPath, withIntermediateDirectories: true, attributes: nil, error: nil)
// 注:withIntermediateDirectories表示当创建的目录完整路径不满足时,是否递归创建完整路径
文件
// 存储一个普通的文本文件
let stringContent = "Contnets of test"
// 将文本内容转换成NSData内容
let stringNSData = stringContent.dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: true)
// 保存文本
fileManager.createFileAtPath(textPath, contents: stringNSData, attributes: nil)

读取

递归遍历指定目录下所有内容
var recursivelyResult = fileManager.subpathsOfDirectoryAtPath(documents, error: nil)
println(recursivelyResult)
遍历指定目录下内容
var contentResult = fileManager.contentsOfDirectoryAtPath(documents, error: nil)
println(contentResult)
判断一个文件或者文件夹是否存在
var aDir = documents + "/a"
var exsit = fileManager.fileExistsAtPath(aDir)
println(exsit)
获取一个文件或目录的属性
var attributes = fileManager.attributesOfItemAtPath(aDir, error: nil)
println(attributes)
设置文件或目录属性
Bool:   fileManager.setAttributes(<#attributes: [NSObject : AnyObject]#>, ofItemAtPath: <#String#>, error: <#NSErrorPointer#>)
读取文件内容
let content = fileManager.contentsAtPath(textPath)
println(content)

移动(重命名)文件夹/文件

let newPath = documentDir + "/new.jpg"
fileManager.moveItemAtPath(imagePath, toPath: newPath, error: nil)

删除文件或文件夹

fileManager.removeItemAtPath(<#path: String#>, error: <#NSErrorPointer#>)

比较两个文件内容是否相同

let result = fileManager.contentsEqualAtPath(image, andPath: imagePath)

读权限

Bool:   fileManager.isReadableFileAtPath(<#path: String#>)

写权限

Bool:   fileManager.isWritableFileAtPath(<#path: String#>)

NSString类路径处理方法(工具方法)

NSString:pathWithComponens:components  //根据components中的元素构造有效路径
NSArray:pathComponents  //析构路径,获得组成此路径的各个部分
NSString:lastPathComponent  //提取路径的最后一个组成部分
NSString:pathExtension  //从路径的最后一个组成部分中提取其扩展名
NSString:stringByAppendingPathComponent:path  //将path添加到现有路径的末尾
NSString:stringByAppendingPathExtension:ext  //将指定的扩展名添加到路径的最后一个组成部分
NSString:stringByDeletingLastPathComponent  //删除路径的最后一个组成部分
NSString:stringByDeletingPathExtension  //从文件的最后一部分删除扩展名
NSString:stringByExpandingTileInPath   //将路径中代字符扩展成用户主目录(~)或指定用户的主目录(~user)
NSString:stringByresolvingSymlinksInPath  //尝试解析路径中的符号链接
NSString:stringByStandardizingPath  //通过尝试解析~、..(父目录符号)、.(当前目录符号)和符号链接来标准化路径

示例:

首先预定义一个文件路径:

var filePath: NSString = "/Uesrs/anoxia/My love.mp3"
  • 获取组成路径的各个部分:
println(filePath.pathComponents)
// 输出NSArray:[/, Uesrs, anoxia, My love.mp3]
  • 活路路径的最后一个组成部分:
println(filePath.lastPathComponent)
// 输出:NSString:My love.mp3
  • 删除路径额的最后一个组成部分:
println(filePath.stringByDeletingLastPathComponent)
// 输出:NSString:/Uesrs/anoxia
  • 在路径最后添加路径:
var appendPath = "file.txt"
println(filePath.stringByAppendingPathComponent(anotherPath))
// 输出:NSString:/Uesrs/anoxia/My love.mp3/text.a
  • 获取文件路径的扩展:
println(filePath.pathExtension)
// 输出: NSString:mp3
  • 在路径最后面追加扩展名:
println(filePath.stringByAppendingPathExtension("a"))
// 输出:NSString(Optional):Optional("/Uesrs/anoxia/My love.mp3.a")
  • 遍历应用目录
let filemanager: NSFileManager = NSFileManager()
let files = filemanager.enumeratorAtPath(NSHomeDirectory())
while let file: AnyObject = files?.nextObject() {
println(file)
}

 

 

Swift\本地文件管理的更多相关文章

  1. Swift - 本地数据的保存与加载(使用NSCoder将对象保存到.plist文件)

    下面通过一个例子将联系人数据保存到沙盒的“documents”目录中.(联系人是一个数组集合,内部为自定义对象). 功能如下: 1,点击“保存”将联系人存入userList.plist文件中 2,点击 ...

  2. Swift - 本地消息的推送通知(附样例)

    使用UILocalNotification可以很方便的实现消息的推送功能.我们可以设置这个消息的推送时间,推送内容等. 当推送时间一到,不管用户在桌面还是其他应用中,屏幕上方会都显示出推送消息. 1, ...

  3. Swift 本地推送通知UILocalNotification

    Notification是智能手机应用开发中常用的信息传递机制,它不用消耗更多资源去不停的检查信息状态,可以非常好的节省资源. 在iOS中分为两种通知:本地.远程.本地的UILocalNotifica ...

  4. swift - 本地通知2 - 啰嗦版

    1. import UIKit @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { var windo ...

  5. swift - 本地通知

    1. AppDelegate  注册 class AppDelegate: UIResponder, UIApplicationDelegate { var window: UIWindow? fun ...

  6. Java语言实现简单FTP软件------>本地文件管理模块的实现(九)

    首先看一下界面: 1.本地文件列表的显示功能 将本地的当前目录下所有文件显示出来,并显示文件的属性包括文件名.大小.日期.通过javax.swing.JTable()来显示具体的数据.更改当前文件目录 ...

  7. iOS - Swift NSFileManage 文件管理

    前言 public class NSFileManager : NSObject public class NSFileHandle : NSObject, NSSecureCoding NSFile ...

  8. [deviceone开发]-基础文件管理器

    一.简介 主要实现本地文件管理功能,主要功能为复制.粘贴.剪切目录或者文件. 二.效果 三.相关下载 https://github.com/do-project/code4do/tree/master ...

  9. 免费的在线Web文件管理器:Net2FTP,Pydio,eXtplorer,KodExplorer–功能强大

    https://www.freehao123.com/web-ftp/ 经常有朋友在使用一些没有带文件管理器的空间时,苦于没有办法来解压上传的文件压缩包,而如果不先上传压缩包,直接上传文件夹的话耗费的 ...

随机推荐

  1. Android中GridView、ListView 的 getChildAt() 方法返回null 问题

    开发的Android app用到了GridView或者ListView,通常使用getChildAt(int position)方法获取当前点击或者选中的View(即position对应的View). ...

  2. tomcat 配置SSL

    本教程使用 JDK 6 和 Tomcat 7,其他版本类似. 基本步骤: 使用 java 创建一个 keystore 文件 配置 Tomcat 以使用该 keystore 文件 测试 配置应用以便使用 ...

  3. Jbpm工作流表补数记录

    一: 历史数据表 11.  JBPM4_HIST_ACTINST 流程活动(节点)实例表 存放Activity Instance的历史记录 12.  JBPM4_HIST_DETAIL  流程历史详细 ...

  4. 广播与P2P通道(下) -- 方案实现

    在广播与P2P通道(上) -- 问题与方案 一文中,我们已经找到了最优的模型,即将广播与P2P通道相结合的方案,这样能使服务器的带宽消耗降到最低,最大节省服务器的宽带支出.当然,如果从零开始实现这种方 ...

  5. [ An Ac a Day ^_^ ] CodeForces 586C Gennady the Dentist 模拟

    题意: n个小朋友去拔牙 每个小朋友在拔牙的时候会哭 哭声是vi分贝 距离门口vi远的小朋友听到了哭声会害怕 他们的勇气值p会减少d 如果勇气值p小于等于零 他们就会在门外哭并立即离开拔牙队列(回家找 ...

  6. CodeForces 697B Barnicle 模拟

    强行模拟 纪念一下…… #include<stdio.h> #include<iostream> #include<algorithm> #include<m ...

  7. (转载)app ico图标字体制作

    图标字体化浅谈   在做手机端Web App项目中,经常会遇到小图标在手机上显示比较模糊的问题,经过实践发现了一种比较好的解决方案,图标字体化.在微社区项目中,有很多小的Icon(图标),如分享.回复 ...

  8. EXEC 和 SP_EXECUTESQL的区别

    摘要: MSSQL为我们提供了两种动态执行sql语句的命令:EXEC 和 SP_EXECUTESQL.通常SP_EXECUTESQL更具优势,因为它提供了输入输出的接口,且能够重用执行计划,大大提高执 ...

  9. 21.编写一个Java应用程序,该程序包括3个类:Monkey类、People类和主类 E。要求: (1) Monkey类中有个构造方法:Monkey (String s),并且有个public void speak() 方法,在speak方法中输出“咿咿呀呀......”的信息。 (2)People类是Monkey类的子类,在People类中重写方法speak(),在speak方法 中输出“小样

    //Monkey类 package d922; public class Monkey { Monkey() { } Monkey (String s) { System.out.println(s) ...

  10. manifest中的largeHeap是干什么用的?

    转 http://blog.csdn.net/jiaoyang623/article/details/8773445 今天群里有人讨论怎么给app分配超过100M的内存,有人亮出了largeHeap参 ...