#import <Foundation/Foundation.h>
#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;
}