objective-C NSFileManager的方法(文件操作)

#import 

#define PATH @"/Users/huzhiping/Desktop/Code"

int main(int argc, const char * argv[]) {
    @autoreleasepool {
        // NSFileManager 是一个专门用来管理文件和文件夹的类,通过一系列的对象方法
        //1.创建一个NSFileMananer对象(单例对象)
        //系统提供的单例方法,一般是以default开头
        NSFileManager *manager = [NSFileManager defaultManager];
            
        //2. 浅度遍历
        //作用:返回当前文件夹下的所有的文件和文件夹(不包含子目录)
        // 参数1:文件夹的路径(绝对路径)
        // 参数2:错误信息(NSError 是OC中专门用来存储错误信息的类,一般不要程序员给他赋值)
        // 如果遍历成功了这个NSError的是空,否则NSError的值就不为空,存储错误信息。

        NSError *error;
        NSArray *array1 = [manager contentsOfDirectoryAtPath:PATH error:&error];
        // 判断遍历是否成功
        if (!error) {
            NSLog(@"遍历成功");
            NSLog(@"%@", array1);
        } else {
            NSLog(@"遍历失败");
            NSLog(@"%@", error);
        }
             
        
        //3. 深度遍历
        //作用:遍历出当前文件夹下的所有的文件和文件夹的名字
        // 包含子目录的相对路径名和子目录下的文件)
        // 参数1:文件夹的路径(绝对路径)
        // 参数2:错误信息(NSError 是OC中专门用来存储错误信息的类,一般不要程序员给他赋值)
        // 如果遍历成功了这个NSError的是空,否则NSError的值就不为空,存储错误信息。

        error = nil;
        NSArray *array2 = [manager subpathsOfDirectoryAtPath:PATH error:&error];
        if (!error) {
            NSLog(@"遍历成功");
            NSLog(@"%@", array2);
        } else {
            NSLog(@"遍历失败");
            NSLog(@"%@", error);
        }
                
        //4.创建文件夹
        // 作用:在制动的路径下创建一个文件夹
        //参数1:路径(不能只是包含需要创建文件夹的路径,还需要包含需要创建的文件夹的名字)      
        // 就是假设已经创建好的文件夹的路径
        // 参数2:是否创建中间目录 推荐传入YES
        // 参数3:文件夹属性,传入nil表示默认属性
        // attributes 属性
        // 参数4: 错误信息
        // 返回值是一个布尔值 是否创建成功
        
        // 拼接路径
        NSString *newPath = [NSString stringWithFormat:@"%@/c", PATH];
        BOOL ret = [manager createDirectoryAtPath:newPath withIntermediateDirectories:YES attributes:nil error:nil];
        if (ret) {
            NSLog(@"创建文件夹成功");
        } else {
            NSLog(@"创建文件夹失败");
   
        }
        
        // 5.创建文件
        //参数1:路径,你要创建的文件创建好的时候的路径
        // 参数2:文件内容(二进制形式)
        //将数据存到文件中或者从文件中取出数据,这个数据类型都是二进制形式的)
        // 参数3:文件属性
        // 返回值是布尔值: 是否创建成功
        
        // 专门用来拼接路径的方法
        NSString *newPath2 = [PATH stringByAppendingPathComponent:@"file.txt"];
        
        //创建内容字符串
        NSString *content = @"Hello, world!";
        // 将字符串转换成NSData 这是字符串对象的方法
        NSData *data = [content dataUsingEncoding:NSUTF8StringEncoding];
        // 创建文件
        BOOL ret2 = [manager createFileAtPath:newPath2 contents:data attributes:nil];
        ret2 ? NSLog(@"文件创建成功"):NSLog(@"文件创建失败");
        
        
        // 6.删除文件或者文件夹
        // 参数1:要删除的文件或者文件夹的路径
        // 参数2:错误信息
        // 返回值布尔值: 是否删除成功
        BOOL ret3 = [manager removeItemAtPath:[PATH stringByAppendingPathComponent:@"c"] error:nil];
        ret3 ? NSLog(@"文件夹删除成功"):NSLog(@"文件夹删除失败");
        
        
        
        // 7.判断文件或者文件夹是否存在
        // 参数1:文件或者文件夹的路径
        // 返回值布尔值: 是否存在
        bool ret4 = [manager fileExistsAtPath:[PATH stringByAppendingPathComponent:@"file.txt"]];
        ret4 ? NSLog(@"存在"):NSLog(@"不存在");
        
        // 8.判断文件或者文件夹是否存在并且判断是否是文件夹
        // 参数1:文件或者文件夹的路径
        // 参数2:用来存储是否是文件夹的结果,如果是文件夹那么这个参数的指向的变量值会变成YES,否则是NO.
        // 返回值布尔值: 是否存在
        BOOL ret6 = NO;
        BOOL ret5 = [manager fileExistsAtPath:[PATH stringByAppendingPathComponent:@"file.txt"] isDirectory:&ret6];
        if (ret5) {
            NSLog(@"存在");
            if (ret6) {
                NSLog(@"是文件夹");
            } else {
                NSLog(@"不是文件夹");
            }
        } else {
             NSLog(@"不存在");
        }
        
        
        // 9.获取文件或者文件夹的属性
        // 参数1:路径
        // 参数2:错误信息
        // 返回值是字典
        NSDictionary *dict = [manager attributesOfItemAtPath:PATH error:nil];
        
        NSLog(@"%@", dict);
        
        
        // 10.拷贝文件或者文件夹
        // 参数1:文件或者文件夹的原始路径
        //参数2:文件或者文件夹的目标路径 (注意:一定要拼接出拷贝完后,文件或者文件夹的路径)
        // 参数3:错误信息
        // 返回值是否拷贝成功
        BOOL ret7 = [manager copyItemAtPath:[PATH stringByAppendingPathComponent:@"file.txt"] toPath:[PATH stringByAppendingPathComponent:@"m/file.txt"] error:nil];
        ret7 ? NSLog(@"拷贝成功"):NSLog(@"拷贝失败");
        
        // 11.文件或者文件夹的移动
        // 参数1:文件或者文件夹的原始路径
        // 参数2:文件或者文件夹的目标路径 (注意:一定要拼接出拷贝完后,文件或者文件夹的路径)
        // 参数3:错误信息
        // 返回值是否移动成功
        
        bool ret8 = [manager moveItemAtPath:[PATH stringByAppendingPathComponent:@"n"] toPath:[PATH stringByAppendingPathComponent:@"m/n"] error:nil];
        ret8 ? NSLog(@"移动成功"):NSLog(@"移动失败");
    }
    return 0;
}

你可能感兴趣的:(objective-C NSFileManager的方法(文件操作))