统计文件行数
来源:互联网 发布:美国医疗大数据公司 编辑:程序博客网 时间:2024/05/16 16:55
统计一个目录下所有普通文件的总行数
方案一:find . -type f -name "*.c" -exec cat {} \; | grep -v '^$' | wc -l
解释:find . -type f -name "*.c" 查找当前目录下所有以.c结尾的文件,如果不考虑文件类型,可以直接实用find . -type f即可。 -exec cat {} \; 是将找到的文件采用cat命令输出; grep -v '^$' 是将不是空行的内容进行统计,如果是空行就不统计,它相当于一个过滤器。 wc -l 统计输出来的代码的行数。如果不需要对空行进行过滤的话,可以省去grep -v '^$'
方案二:find . -type f -exec wc -l {} \; | awk '{sum+=$1}END{print sum}'
解释:find命令同方案一。-exec wc -l 是指将找到的文件依次计算其中的行数,此时如果输出的话,会输出类似于
22 main.c
43 head1.h
67 head1.c
所以还要采用awk将第一列进行相加,由sum+=$1,很明显,比较容易理解awk的含义。但此种方法没有对空行进行过滤。
方案三:find . -type f | xargs wc -l
解释:使用xargs与方案二的差异在于在使用find命令的-exec选项处理匹配到的文件时, find命令将所有匹配到的文件一起传递给exec执行。但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现 溢出错误。错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。
find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。
对于方案三,系统会显示每个文件的行数,然后显示总行数:
14 ./main.c
8 ./abc.c
8 ./folder/main.c
8 ./folder/shaoning/test.c
38 总用量
- Linux统计文件行数
- Linux统计文件行数
- Linux统计文件行数
- 统计文件行数
- Linux统计文件行数
- 统计文件行数
- Linux统计文件行数
- Linux统计文件行数
- Linux统计文件行数
- Linux统计文件行数
- 统计文件的行数
- 统计文件行数
- 统计文件内容行数
- Linux统计文件行数
- Linux统计文件行数
- hadoop统计文件行数
- 统计文件行数
- 统计文件行数
- 维度模型数据仓库(七) —— 按需装载
- linux 12个进程管理命令
- 为什么干活利索要比你想象中重要的多?
- Requests介绍与安装
- 循环链表
- 统计文件行数
- 服务器web目录权限配置
- 散列表查找(哈希表)的基本操作 (完整代码)
- 软件测试基本概念(2)
- Android 开发最佳实践
- 知识框架要成体系
- 微信公众号智能识别回复的实现(基于ThinkPHP框架)
- Android基础入门教程——8.3.14 Paint几个枚举-常量值以及ShadowLayer阴影效果
- Java之UncaughtExceptionHandler