iOS

前言

	@interface NSFileManager : NSObject
	@interface NSFileHandle : NSObject <NSSecureCoding>
  • NSFileManager 是 Foundation 框架中用来管理和操作文件、目录等文件系统相关联内容的类。

1、路径操作

	// 文件管理器对象,单例类对象
	NSFileManager *nfManager = [NSFileManager defaultManager];
		
	NSURL *folderUrl = [NSURL URLWithString:[NSHomeDirectory() stringByAppendingString:@"/Desktop/testFolder"]];
	NSURL *filerUrl = [NSURL URLWithString:[NSHomeDirectory() stringByAppendingString:@"/Desktop/testFile.txt"]];
	    
	NSURL *srcUrl = [NSURL URLWithString:[NSHomeDirectory() stringByAppendingString:@"/Desktop/testFile.txt"]];
	NSURL *dstUrl = [NSURL URLWithString:[NSHomeDirectory() stringByAppendingString:@"/Desktop/testFolder/testFile.txt"]];
	    
	// 用于保存错误信息
	NSError *errorInfo = nil;
	    
	// 创建文件夹
	/*
		-(BOOL)createDirectoryAtPath:(NSString *)path withIntermediateDirectories:(BOOL)createIntermediates 
		                                                               attributes:(NSDictionary *)attributes 
		                                                                    error:(NSError **)error;
		 
		path:文件夹路径
		createIntermediates:是否连同上一级路径一起创建,NO 并且上一级文件路径不存在时会创建失败。
		attributes:文件夹属性,nil 系统默认属性
		error:保存错误原因
		BOOL:文件夹创建成功时返回值为 YES
	*/
	    
	BOOL bl1 = [nfManager createDirectoryAtPath:[folderUrl path] withIntermediateDirectories:YES 
	                                                                              attributes:nil 
	                                                                                   error:&errorInfo];
	
	// 创建文件
	/* 
		-(BOOL)createFileAtPath:(NSString *)path contents:(NSData *)data attributes:(NSDictionary *)attr;
		 
		path:文件路径
		data:文件内容,nil 空
		attr:文件属性,nil 系统默认属性
		BOOL:文件创建成功时返回值为 YES
	*/
	    
	BOOL bl2 = [nfManager createFileAtPath:[filerUrl path] 
	                              contents:[@"北京欢迎您" dataUsingEncoding:NSUTF8StringEncoding] 
	                            attributes:nil];
	
    // 拷贝文件
    /*
    	如果 dstUrl 路径文件已存在,该方法会终止拷贝,并返回 false。
    	如果 srcUrl 的最后一部分是符号链接,那么只有链接会被拷贝到新路径。
    */
    
	BOOL bl3 = [nfManager copyItemAtPath:[srcUrl path] toPath:[dstUrl path] error:nil];
	
	// 删除文件
	/*
		删除成功或者 url 为 nil 时返回 true,如果发生错误返回 false。如果使用 delegate 
		终止了删除文件,则返回 true,如果使用 delegate 终止了删除目录,则返回 false
	*/
	
	BOOL bl4 = [nfManager removeItemAtPath:[dstUrl path] error:nil];
	
	// 移动文件
	/*
		如果 dstUrl 路径文件已存在,该方法会终止移动,并返回 false。如果 srcUrl 的最后 
		一部分是符号链接,那么只有链接会被移动到新路径。链接所指向的内容仍然保持在现有的位置。
	*/

	BOOL bl5 = [nfManager moveItemAtPath:[srcUrl path] toPath:[dstUrl path] error:nil];
	
	// 查找满足指定条件的路径

		// 返回其 URL。该方法不但可以获得标准系统目录,还可以用来创建临时路径
    	NSURL *url1 = [nfManager URLForDirectory:NSDocumentDirectory 
    	                                inDomain:NSUserDomainMask 
    	                       appropriateForURL:nil 
    	                                  create:YES 
    	                                   error:nil];

		// 返回所有满足条件的路径列表
    	NSArray *urlObjs = [nfManager URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask];
    	NSURL *url2 = urlObjs[0];
	
    // 查询指定路径下的所有子路径

    NSArray *urls1 = [nfManager subpathsAtPath:[url1 path]];
    NSArray *urls2 = [nfManager subpathsOfDirectoryAtPath:[url1 path] error:nil];
	
	// 浅遍历

		// 返回指定目录下的文件、子目录及符号链接的列表
		NSArray *contentsDir1 = [nfManager contentsOfDirectoryAtPath:[url1 path] error:nil];
    
		// 返回的是文件全路径
		NSArray *contentsDir2 = [nfManager contentsOfDirectoryAtURL:url1 
   		                                 includingPropertiesForKeys:nil 
   		                                                    options:NSDirectoryEnumerationSkipsHiddenFiles 
   		                                                      error:nil];

	// 深遍历

		// 返回指定目录下的所有文件及其子目录下的所有元素路径
    	NSDirectoryEnumerator *enumeratorDir1 = [nfManager enumeratorAtPath:[url1 path]];
    	
    	// 返回的是文件全路径
    	NSDirectoryEnumerator *enumeratorDir2 = [nfManager enumeratorAtURL:url1 
    	                                        includingPropertiesForKeys:nil 
    	                                                           options:NSDirectoryEnumerationSkipsHiddenFiles 
    	                                                      errorHandler:nil];
		
		// 枚举遍历深层遍历
    	NSDirectoryEnumerator *dEnu = [nfManager enumeratorAtPath:[url1 path]];
    	
		id obj = nil;
		while (obj = [dEnu nextObject]) {
			NSLog(@"%@", obj);
		}

	// 显示路径的本地化名称
	/*
		// 如果指定的文件或目录不存在,会返回 path 本身
	*/
	NSString *displayName = [nfManager displayNameAtPath:[url1 path]];
	
	// 获取指定路径的各种属性

	NSDictionary *attributes = [nfManager attributesOfItemAtPath:[url1 path] error:nil];
	
	// 获取指定路径文件的内容数据
	/*
		如果指定路径为目录或发生错误,返回 nil
	*/
	NSData *data = [nfManager contentsAtPath:[[url1 path] stringByAppendingString:@"/test.txt"]];
	
	// 获取当前路径

	NSString *currentPath = [nfManager currentDirectoryPath];
	
	// 更改当前路径
	/*
		/Users/JHQ0228/Desktop/Debug
	*/
	BOOL bl6 = [nfManager changeCurrentDirectoryPath:[NSHomeDirectory() stringByAppendingString:@"/Desktop/Debug"]];
	
	// 获取临时工作路径
	/*
		获取系统中可以用来创建临时文件的目录路径名,一定要在完成任务之后将在其中创建的文件删除
	*/
	NSString *tempPath = NSTemporaryDirectory();
	
	// 获取用户主路径(沙盒路径)

	NSString *homePath = NSHomeDirectory();
	
	// 获取指定用户的主路径
	/*
		NSUserName(); 获取当前用户的登录名。NSFullUserName(); 获取当前用户完整用户名
	*/
	NSString *userHomePath = NSHomeDirectoryForUser(NSUserName());
	
	// 获取用户 Documents 路径

	NSString *documentPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];
	
	// 获取 app 包路径

	NSString *bundlePath = [[NSBundle mainBundle] bundlePath];
 	
	// 创建一个新路径

	BOOL bl8 = [nfManager createDirectoryAtPath:[NSHomeDirectory() stringByAppendingString:@"/Desktop/Debug1"] 
	                withIntermediateDirectories:YES 
	                                 attributes:nil 
	                                      error:nil];
	
	// 判断文件是否为路径(flag 中存储结果 YES/NO)

		// 存储判断结果
		BOOL result;
		
		BOOL bl9 = [nfManager fileExistsAtPath:[NSHomeDirectory() stringByAppendingString:@"/Desktop/test.txt"] 
		                           isDirectory:&result];
	
	// 判断是否是根路径(绝对路径)
	/*
		路径以 “/” 开始的为根路径
	*/

	BOOL bl10 = [@"../Desktop/test.txt" isAbsolutePath];
	
	// 获取最后一个路径

	NSString *lastPath = [[NSHomeDirectory() stringByAppendingString:@"/Desktop"] lastPathComponent];
	
	// 删除最后一个路径

	NSString *deleteLastPath = [[NSHomeDirectory() stringByAppendingString:@"/Desktop"] stringByDeletingLastPathComponent];
	
	// 拼接一个路径

	NSString *appendingPath = [[NSHomeDirectory() stringByAppendingString:@"/Desktop"] stringByAppendingPathComponent:@"testFolder"];
	
	// 文件路径分割

	NSArray *pathArray = [[NSHomeDirectory() stringByAppendingString:@"/Desktop"] pathComponents];
	
	// 文件路径组合

	NSString *pathString = [NSString pathWithComponents:pathArray];
	
	// 将路径中的代字符 ~ 扩展成用户主目录或指定用户的主目录

		// 特殊的代字符 ~ 是用户主目录(如:/Users/JHQ0228)的缩写,~linda 表示用户 linda 主目录的缩写
		NSString *path1 = @"~/Desktop/test.txt";

		// /Users/JHQ0228/Desktop/test.txt
   		NSString *mainPath = [path1 stringByExpandingTildeInPath];
	
	// 解析路径中的符号链接

		// /..    上一级目录
		NSString *path2 = @"~/../Debug";
	
		// 通过解析 ~(用户主目录)、..(父目录) 、.(当前目录)和符号链接来标准化路径
		NSString *appPath1 = [path2 stringByResolvingSymlinksInPath];
    
		// NSHomeDirectory()/..    NSHomeDirectory() 的上一级目录
    	NSString *path3 = [NSString stringWithFormat:@"%@/../Debug", NSHomeDirectory()];
    	NSString *appPath2 = [path3 stringByStandardizingPath];
	
	// 获取文件拓展名

	NSString *getExtension = [@"/Desktop/test.txt" pathExtension];
	
	// 删除文件拓展名

	NSString *deleteExtension = [@"/Desktop/test.txt" stringByDeletingPathExtension];
	
	// 拼接文件拓展名

	NSString *appendingExtension = [@"/Desktop/test.txt" stringByAppendingPathExtension:@"doc"];
	
	// 获取文件大小
    
	NSDictionary *dict = [[NSFileManager defaultManager] attributesOfItemAtPath:filerUrl.path error:NULL];
	long long fileSize = [dict[NSFileSize] longLongValue];
	long long fileSize = [dict fileSize];

2、路径判断

	NSFileManager *nfManager = [NSFileManager defaultManager];
	NSURL *url1 = [nfManager URLForDirectory:NSDocumentDirectory 
	                                inDomain:NSUserDomainMask 
	                       appropriateForURL:nil 
	                                  create:YES 
	                                   error:nil];
    
	// 判断路径是否存在
	/*
		如果当前路径以~开头,需使用 NSString 的 stringByExpandingTildeInPath 方法进行处理,否则会返回 false
	*/

	BOOL bl1 = [nfManager fileExistsAtPath:[url1 path]];
	
	// 判断指定路径是否有可读权限

	BOOL bl2 = [nfManager isReadableFileAtPath:[url1 path]];
 	
	// 判断指定路径是否有可写权限

	BOOL bl3 = [nfManager isWritableFileAtPath:[url1 path]];
	
	// 判断指定路径是否有可执行权限

	BOOL bl4 = [nfManager isExecutableFileAtPath:[url1 path]];
	
	// 判断指定路径是否有可删除权限

	BOOL bl5 = [nfManager isDeletableFileAtPath:[url1 path]];
 	
	// 判断两个指定路径的内容是否相同

	BOOL bl6 = [nfManager contentsEqualAtPath:[url1 path] andPath:[[url1 path] stringByAppendingString:@"/test.txt"]];

3、文件操作

	NSURL *fileUrl = [[NSFileManager defaultManager] URLsForDirectory:NSDocumentDirectory inDomains:NSUserDomainMask][0];
    
	// 文件打开
    
		NSFileHandle *nfHandle = [NSFileHandle fileHandleForUpdatingAtPath:[[fileUrl path] stringByAppendingString:@"/test.txt"]];
        
		NSFileHandle *nfHandle1 = [NSFileHandle fileHandleForReadingAtPath:[[fileUrl path] stringByAppendingString:@"/test.txt"]];
        
		NSFileHandle *nfHandle2 = [NSFileHandle fileHandleForWritingAtPath:[[fileUrl path] stringByAppendingString:@"/test.txt"]];
    
	// 文件句柄偏移量
    
		// 获取文件句柄指针的偏移量
		unsigned long long offSetNum1 = [nfHandle offsetInFile];
			
		// 将偏移量移到文件末尾,返回移动后的指针偏移量
		unsigned long long offSetNum2 = [nfHandle seekToEndOfFile];
		 	
		// 将偏移量指向特定的位置
		[nfHandle seekToFileOffset:0];
 	
	// 文件读取
    
		// 获取当前文件句柄的可用数据,获取后指针移到文件末尾
		NSData *availableData = [nfHandle availableData];
		  	
		// 获取从当前指针位置到文件结束的所有数据,获取后指针移到文件末尾
		NSData *data1 = [nfHandle readDataToEndOfFile];
			
		// 获取从当前指针位置开始读取的 length 长度的数据内容,获取后指针移到文件读取到的位置
		NSData *data2 = [nfHandle readDataOfLength:10];
    	
	// 文件写入
    
		// 从当前指针位置写入数据到文件
		[nfHandle writeData:[@"你好" dataUsingEncoding:NSUTF8StringEncoding]];
    	
	// 文件关闭
    
    	// 关闭文件
		[nfHandle closeFile];
    
	// 文件比较
    
		NSFileManager *nfManager = [NSFileManager defaultManager];
		    
		// 文件路径
		NSString *filePath1 = [NSHomeDirectory() stringByAppendingString:@"/Desktop/file1.txt"];
		NSString *filePath2 = [NSHomeDirectory() stringByAppendingString:@"/Desktop/file2.txt"];
		    
		[nfManager createFileAtPath:filePath1 
		                   contents:[@"北京欢迎您" dataUsingEncoding:NSUTF8StringEncoding] 
		                 attributes:nil];
		                 
		[nfManager createFileAtPath:filePath2 
		                   contents:[@"北京欢迎" dataUsingEncoding:NSUTF8StringEncoding] 
		                 attributes:nil];
		    
		// 比较两个文件的内容是否相等
		BOOL bl = [nfManager contentsEqualAtPath:filePath1 andPath:filePath2];
原文地址:https://www.cnblogs.com/QianChia/p/5782855.html