所有方法

都很简单,大概记录一下,写文件并没有是追加的方式而是简单的覆盖

//创建文件夹
- (BOOL)creatDir:(NSString*)newDirName at:(NSString*)dirName ;
//创建文件
- (BOOL)creatFile:(NSString*)fileName at:(NSString*)dirName ;
//写文件-字符串
- (BOOL)writeString:(NSString*)string inFilePath:(NSString*)filePath;
//写文件-字典
- (BOOL)writeDict:(NSDictionary*)dict inFilePath:(NSString*)filePath ;
//写文件-数组
- (BOOL)writeArray:(NSArray*)array inFilePath:(NSString*)filePath ;
//读文件
- (NSString*)readFileAt:(NSString*)filePath;
//获取某个目录下所有文件
- (NSArray*)getAllFileAtDir:(NSString*)dirPath ;
//判断文件是否存在
- (BOOL)fileIsExistAtPath:(NSString*)filePath ;
//计算某个文件大小
- (unsigned long long)computerFileSizeAtPath:(NSString*)filePath;
//计算整个文件夹中所有文件大小
- (unsigned long long)computerDirSizeAtPath:(NSString*)dirPath;
//删除文件
- (BOOL)removeFileAtPath:(NSString*)filePath;
//移动文件
- (BOOL)moveFile:(NSString*)fileName fromPath:(NSString*)fromPath toPath:(NSString*)toPath;

具体实现

初始化一下NSFileManager 并获取根路径

主要是加了一些判断,代码不是很精简 不要笑我。

- (instancetype)init {
self = [super init];
if (self) {
self.homePath = NSHomeDirectory();
self.manager = [NSFileManager defaultManager];
NSLog(@"根路径地址:%@",self.homePath);
}
return self;
}
//创建文件夹
- (BOOL)creatDir:(NSString*)newDirName at:(NSString*)dirName {
NSString *path = [self.homePath stringByAppendingString:dirName];
NSString *filePath = [path stringByAppendingPathComponent:newDirName];
if ([self.manager fileExistsAtPath:filePath]) {
NSLog( @"创建失败,目录已存在");
}else {
BOOL isCreate = [self.manager createDirectoryAtPath:filePath withIntermediateDirectories:NO attributes:nil error:nil];
if (isCreate) {
NSLog( @"创建成功");
return YES;
} else {
NSLog( @"创建失败,请检查路径");
return NO;
}
}
return NO;
}
//创建文件
- (BOOL)creatFile:(NSString*)fileName at:(NSString*)dirName {
//目录位置
NSString *dirPath = [self.homePath stringByAppendingString:dirName];
//文件位置
NSString *filePath = [dirPath stringByAppendingPathComponent:fileName];
BOOL isDir = NO;
BOOL isFileExist = [self.manager fileExistsAtPath:dirPath isDirectory:&isDir];
//目录是否存在
if (!(isFileExist && isDir)) {
NSLog(@"目录不存在,请先创建目录");
return NO;
}
//文件是否存在
if (![self.manager fileExistsAtPath:filePath]) {
BOOL isCreate = [self.manager createFileAtPath:filePath contents:nil attributes:nil];
if (isCreate) {
NSLog(@"创建成功");
return YES;
} else {
NSLog(@"创建失败");
return NO;
}
}
else {
NSLog(@"创建失败,文件已存在");
return NO;
}
return NO;
}
//写文件-字符串
- (BOOL)writeString:(NSString*)string inFilePath:(NSString*)filePath{
NSString *path = [self.homePath stringByAppendingString:filePath];
BOOL isFileExist = [self.manager fileExistsAtPath:path];
if (isFileExist) {
BOOL isWrite = [string writeToFile:path atomically:YES encoding:NSUTF8StringEncoding error:nil];
if (isWrite) {
NSLog(@"写入成功");
return YES;
} else {
NSLog( @"写入失败");
return NO;
}
}else{
NSLog(@"文件不存在,请先创建文件");
return NO;
}
return NO;
}
//写文件-字典
- (BOOL)writeDict:(NSDictionary*)dict inFilePath:(NSString*)filePath {
NSString *path = [self.homePath stringByAppendingString:filePath];
BOOL isFileExist = [self.manager fileExistsAtPath:path];
if (isFileExist) {
BOOL isWrite = [dict writeToFile:path atomically:YES];
if (isWrite) {
NSLog(@"写入成功");
return YES; } else {
NSLog(@"写入失败");
return NO; }
}else{
NSLog(@"文件不存在,请先创建文件");
return NO; }
return NO; }
//写文件-数组
- (BOOL)writeArray:(NSArray*)array inFilePath:(NSString*)filePath {
NSString *path = [self.homePath stringByAppendingString:filePath];
BOOL isFileExist = [self.manager fileExistsAtPath:path];
if (isFileExist) {
BOOL isWrite = [array writeToFile:path atomically:YES];
if (isWrite) {
NSLog(@"写入成功");
return YES; } else {
NSLog(@"写入失败");
return NO;
}
}else{
NSLog(@"文件不存在,请先创建文件");
return NO;
}
return NO;
}
//读文件
- (NSString*)readFileAt:(NSString*)filePath{
NSString *path = [self.homePath stringByAppendingString:filePath];
NSData *data = [self.manager contentsAtPath:path];
NSString *result = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
return result;
}
//获取某个目录下所有文件
- (NSArray*)getAllFileAtDir:(NSString*)dirPath {
NSString *path = [self.homePath stringByAppendingString:dirPath];
NSArray *dirArray = [self.manager contentsOfDirectoryAtPath:path error:nil];
return dirArray;
}
//判断文件是否存在
- (BOOL)fileIsExistAtPath:(NSString*)filePath {
NSString *path = [self.homePath stringByAppendingString:filePath];
BOOL isFileExist = [self.manager fileExistsAtPath:path];
if (isFileExist) {
NSLog(@"文件存在");
return YES; } else {
NSLog(@"文件不存在");
return NO; }
return NO;
}
//计算某个文件大小 单位是字节
- (unsigned long long)computerFileSizeAtPath:(NSString*)filePath {
NSString *path = [self.homePath stringByAppendingString:filePath];
BOOL isDir;
BOOL isFile = [self.manager fileExistsAtPath:path isDirectory:&isDir];
if (!isDir) {
if (!isFile) {
NSLog(@"文件不存在");
return 0; }else {
unsigned long long fileSize = [self.manager attributesOfItemAtPath:path error:nil].fileSize;
return fileSize;
}
} else {
NSLog( @"该文件是一个目录");
return 0;
}
return 0;
}
//计算整个文件夹中所有文件大小
- (unsigned long long)computerDirSizeAtPath:(NSString*)dirPath {
NSString *path = [self.homePath stringByAppendingString:dirPath];
BOOL isExist = [self.manager fileExistsAtPath:path];
if (isExist) { NSEnumerator *childFilesEnumerator = [[self.manager subpathsAtPath:path] objectEnumerator];
NSString* fileName;
long long folderSize = 0;
while ((fileName = [childFilesEnumerator nextObject]) != nil){
NSString* fileAbsolutePath = [path stringByAppendingPathComponent:fileName];
folderSize += [self.manager attributesOfItemAtPath:fileAbsolutePath error:nil].fileSize;
}
return folderSize; } else {
NSLog(@"目录不存在");
return 0;
}
return 0;
}
//删除文件
- (BOOL)removeFileAtPath:(NSString*)filePath {
NSString *path = [self.homePath stringByAppendingString:filePath];
if ([self.manager fileExistsAtPath:path]) {
BOOL isRemove = [self.manager removeItemAtPath:path error:nil];
if (!isRemove) {
NSLog(@"移除失败");
return NO;
} else {
NSLog(@"移除成功");
return YES;
}
} else {
NSLog(@"文件不存在");
return NO;
}
return NO;
}
//移动文件
- (BOOL)moveFile:(NSString*)fileName fromPath:(NSString*)fromPath toPath:(NSString*)toPath {
NSString *fPath = [self.homePath stringByAppendingString:fromPath];
NSString *src = [fPath stringByAppendingPathComponent:fileName];
NSString *tPath = [self.homePath stringByAppendingString:toPath];
NSString *des = [tPath stringByAppendingPathComponent:fileName]; if (![self.manager fileExistsAtPath:src]) {
NSLog(@"文件不存在");
return NO;
}else {
if (![self.manager fileExistsAtPath:tPath]) {
NSLog(@"目标路径不存在");
return NO;
} else {
BOOL move = [self.manager moveItemAtPath:src toPath:des error:nil];
if (move) {
NSLog( @"移动成功");
return YES;
} else {
NSLog(@"移动失败");
return NO;
}
}
}
return NO;
}

Objective-C NSFileManager的使用 各种文件操作的更多相关文章

  1. 归档NSKeyedArchiver解归档NSKeyedUnarchiver与文件管理类NSFileManager (文件操作)

    ========================== 文件操作 ========================== 一.归档NSKeyedArchiver 1.第一种方式:存储一种数据. // 归档 ...

  2. NSFileManager文件操作的十个小功能

    NSFileManager文件操作的十个小功能 NSFileManager是一个单列类,也是一个文件管理器.可以通过NSFileManager创建文件夹.创建文件.写文件.读文件内容等等基本功能. 下 ...

  3. iOS——文件操作NSFileManager (创建、删除,复制,粘贴)

    iOS——文件操作NSFileManager (创建.删除,复制,粘贴)       iOS的沙盒机制,应用只能访问自己应用目录下的文件.iOS不像android,没有SD卡概念,不能直接访问图像.视 ...

  4. IOS文件操作的两种方式:NSFileManager操作和流操作

    1.常见的NSFileManager文件方法 -(NSData *)contentsAtPath:path //从一个文件读取数据 -(BOOL)createFileAtPath: path cont ...

  5. iOS 沙盒(sandbox)机制和文件操作

    本文参看了 http://www.uml.org.cn/mobiledev/201209211.asp#1 这篇文章中的介绍,尊重原著. 1.IOS沙盒机制 IOS应用程序只能在本应用程序中创建的文件 ...

  6. IOS学习之IOS沙盒(sandbox)机制和文件操作

    IOS学习之IOS沙盒(sandbox)机制和文件操作(一) 1.IOS沙盒机制 IOS应用程序只能在为该改程序创建的文件系统中读取文件,不可以去其它地方访问,此区域被成为沙盒,所以所有的非代码文件都 ...

  7. iOS - 文件操作(File Operating)

    1. 沙盒 & NSData /*_______________________________获取沙盒路径_________________________________________* ...

  8. iOS的沙箱目录和文件操作

    一.沙箱 iOS的每一个应用程序都有自己的目录来存放数据,这个目录称为沙箱目录.沙箱目录是一种数据安全策略,它设计的原理是只能允许自己的应用访问目录,而不允许其他的应用访问,这样可以保证数据的安全,应 ...

  9. 读写应用程序数据-NSUserDefault、对象归档(NSKeyedArchiver)、文件操作

    ios中数据持久化存储方式一般有5种:NSUserDefault.对象归档(NSKeyedArchiver).文件操作.数据库存储(SQLite3).CoreData. 1.NSUserDefault ...

随机推荐

  1. win8安装sql2008及设置登陆名问题

    1. .net3.5安装        使用win8系统自带的升级功能无法成功安装.其实Windows8安装文件中已经集了.Net3.5,       (1)此时只需要使用虚拟光驱加载Windows8 ...

  2. [Open Source] 负载均衡之Nginx

    目录 简介 常用命令 功能 代理 反向代理 集群 HTTP集群 TCP集群 重定向 静态文件 HTTPS配置 常见问题 简介 Nginx ("engine x") 是一款轻量级,高 ...

  3. Linux centOS的vm虚拟机配置详细 中文版

    这里以安装cenOS6.6 为例 如果想要需要cenos 6.6 ios文件的朋友看我的另一篇关于cenos6.6版本的下载详细 文中内容是摘抄自老男孩老师的<linux 跟老男孩学Linux运 ...

  4. JAVA类型擦除

    Java泛型-类型擦除 一.概述 Java泛型在使用过程有诸多的问题,如不存在List<String>.class, List<Integer>不能赋值给List<Num ...

  5. AngularJs学习笔记0——前言

    距离上次写博客有很长时间了,这段时间中也一直想坚持写博客,但是迟迟未动,一方面是因为刚换工作并适应新的环境导致工作比较忙碌,一直没有抽出时间来,其实说白了就是给自己的懒惰找借口,但是本人在园子里也有一 ...

  6. jQuery从入门到忘记

    jQuery 是一套Javascript脚本库,注意 jQuery 是脚本库,而不是脚本框架."库"不等于"框架".jQuery 并不能帮助我们解决脚本的引用管 ...

  7. Web开发资料

    慢慢更新 1. Quackit 墙裂推荐!提供了一系列教程,bootstrap的模板也很好用. 2. Bootstrap 4 Cheat Sheet 好用,比官网更加一目了染.  3.Chart. ...

  8. Django+MySQL开发项目:内容管理系统cms(一)

    Baker-Miller Pink被科学方法证实可以平静情绪并且抑制食欲的颜色,具有amazing的效果.基百里面说实验结果表明该颜色具有: "a marked effect on lowe ...

  9. Vijos 1002 过河 状态压缩DP

    描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数轴上 ...

  10. 网络编程学习笔记(二)基于TCP的Socket编程

    1.Socket:英文意思插座.两个Java应用程序可以通过一个双向的网络通信连接实现数据交换,这个双向链路的一端称为一个Socket. 2.Socket通常用来实现client-server(客户端 ...