iOS - OC NSFileManager 文件管理

前言

    @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];
上一篇:buildship,eclipseIDE的gradle插件


下一篇:Nginx配置文件详解