算法积累:解决如何获取指定文件夹路径或者文件路径下所有子文件后缀为.h .m .c的文本的行数

简介:

1、先解决如何获取一个文件的代码行数

一开始对于这个问题,我的思路就回荡在:1字符串子字符串的判断 2循环直到结束的想法 3将原来是"\n"替换掉之类的想法

一个问题总会有多种解决方案,下面的解决方案来自MJ基础视频里讲过的方案,挺不错的,基本思路是:通过"\n"拆分字符串到OC数组中,最后判断数组的长度即可。

虽然有时候我们可能想不到更好的方法,但是也不能阻拦我们去积累好的方法,所以纪录在此博文中。

学习来自 MJ 的某个基础视频

2、然后进一步考虑一个目录下的所有文件以及目录下的子文件的行数

思路:<1>这样的话,首先要处理 path 可以是文件所在目录,也可以是文件夹所在的目录。所以就需要NSFileManager对象来处理文件和文件夹。

  NSFileManager可以判断当前目录是对应的文件还是文件夹。

<2>当如果是文件的话,就执行上面的程序,输出文件的行数。

<3>当如果是文件夹的话,就需要继续执行方法<1>所以这里就需要用递归来处理这种需要重复执行包含的内容。

下面就直接给出MJ的代码:

复制代码
 1 #import <Foundation/Foundation.h>
 2  3 void codeLine(NSString *path)
 4 {
 5 //需要获取的内容  6 NSString* content;
 7 //获取NSFileManager的单例对象  8 NSFileManager *manager = [NSFileManager defaultManager];
 9 //判断path是文件还说路径 10 BOOL isDir;//是否为文件夹 11 BOOL isExist = [manager fileExistsAtPath:path isDirectory:&isDir];//是否存在 12 13 if (!isExist) {
14 NSLog(@"路径下的目录或文件 不存在的");
15  }
16 17 if (isDir) {
18 NSLog(@"是目录文件夹。");
19 //就需要打印所有的子文件夹 20 NSArray *dirArray = [manager contentsOfDirectoryAtPath:path error:nil];
21 //遍历数组中所有的文件和目录 22 for (NSString* fileName in dirArray) {
23 NSString* fileNames = [NSString stringWithFormat:@"%@/%@",path,fileName];
24 NSLog(@"%@",fileNames);
25 //然后递归调用,遇到文件名就输出行数 26  codeLine(fileNames);
27  }
28 }else{
29 content = [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
30 NSArray *array = [content componentsSeparatedByString:@"\n"];
31 //获取文件的行数 32 NSLog(@"行数是:%lu",(unsigned long)array.count);
33  }
34 }
35 36 int main(int argc, const char * argv[]) {
37  @autoreleasepool {
38 // /Users/HeYang/Desktop/HTTP 39 NSString* path = @"/Users/HeYang/Desktop/HTTP";
40  codeLine(path);
41  }
42 return 0;
43 }
复制代码

3、然后进一步解决的问题是:文件为后缀.h .m .c的文本

复制代码
 1 #import <Foundation/Foundation.h>
 2  3 int codeLine(NSString *path)
 4 {
 5 //需要获取的内容  6 NSString* content;
 7 //获取NSFileManager的单例对象  8 NSFileManager *manager = [NSFileManager defaultManager];
 9 //判断path是文件还说路径 10 BOOL isDir;//是否为文件夹 11 BOOL isExist = [manager fileExistsAtPath:path isDirectory:&isDir];//是否存在 12 13 if (!isExist) {
14 NSLog(@"路径下的目录或文件 不存在的");
15 return 0;
16  }
17 NSArray *array;
18 NSString *fullFileName;
19 if (isDir) {
20 //就需要打印所有的子文件夹 21 NSArray *dirArray = [manager contentsOfDirectoryAtPath:path error:nil];
22 //遍历数组中所有的文件和目录 23 for (NSString* fileName in dirArray) {
24 fullFileName = [NSString stringWithFormat:@"%@/%@",path,fileName];
25 //然后递归调用,遇到文件名就输出行数 26  codeLine(fullFileName);
27  }
28 return 0;
29 }else{
30 //还需要判断非指定文件名后缀的文件 31 NSString *extends = [path pathExtension];
32 if (![extends isEqualToString:@"h"]
33 && ![extends isEqualToString:@"c"]
34 && ![extends isEqualToString:@"m"]){
35 return 0;
36  }
37 content = [NSString stringWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
38 array = [content componentsSeparatedByString:@"\n"];
39  }
40 NSLog(@"%@ 的行数是:",path);
41 //获取文件的行数 42 NSLog(@"行数是:%lu",(unsigned long)array.count);
43 return 0;
44 }
45 46 int main(int argc, const char * argv[]) {
47  @autoreleasepool {
48 // /Users/HeYang/Desktop/HTTP 49 NSString* path = @"/Users/HeYang/Desktop/HTTP";
50  codeLine(path);
51  }
52 return 0;
53 }
复制代码
相关文章
|
28天前
|
算法
算法修炼-动态规划之路径问题(1)
算法修炼-动态规划之路径问题(1)
|
1月前
|
算法 Java
算法:Java计算二叉树从根节点到叶子结点的最大路径和
算法:Java计算二叉树从根节点到叶子结点的最大路径和
|
2月前
|
传感器 算法 自动驾驶
混合A*运动规划算法:路径规划和路径跟踪-MPC-LQR-PID算法
混合A*运动规划算法:路径规划和路径跟踪-MPC-LQR-PID算法
75 0
混合A*运动规划算法:路径规划和路径跟踪-MPC-LQR-PID算法
|
2月前
|
算法 测试技术 C++
【动态规划】【图论】【C++算法】1575统计所有可行路径
【动态规划】【图论】【C++算法】1575统计所有可行路径
|
2月前
|
算法
【算法优选】 动态规划之路径问题——贰
【算法优选】 动态规划之路径问题——贰
|
1月前
|
传感器 算法 计算机视觉
基于肤色模型和中值滤波的手部检测算法FPGA实现,包括tb测试文件和MATLAB辅助验证
该内容是关于一个基于肤色模型和中值滤波的手部检测算法的描述,包括算法的运行效果图和所使用的软件版本(matlab2022a, vivado2019.2)。算法分为肤色分割和中值滤波两步,其中肤色模型在YCbCr色彩空间定义,中值滤波用于去除噪声。提供了一段核心程序代码,用于处理图像数据并在FPGA上实现。最终,检测结果输出到&quot;hand.txt&quot;文件。
|
4月前
|
存储 算法
算法编程(二十六):判断路径是否相交
算法编程(二十六):判断路径是否相交
29 0
|
4月前
|
算法 计算机视觉 异构计算
基于FPGA的图像形态学腐蚀算法实现,包括tb测试文件和MATLAB辅助验证
基于FPGA的图像形态学腐蚀算法实现,包括tb测试文件和MATLAB辅助验证
|
28天前
|
算法 机器人
算法沉淀 —— 动态规划篇(路径问题)
算法沉淀 —— 动态规划篇(路径问题)
26 0
|
1月前
|
编解码 算法 计算机视觉
基于FPGA的图像最近邻插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
基于FPGA的图像最近邻插值算法verilog实现,包括tb测试文件和MATLAB辅助验证