一句Shell命令搞定代码行数统计
最粗略版
find . -name "*.java"|xargs wc -l|grep "total"|awk '{print $1}'
find . -name "*.java"|xargs cat|wc -l #Output:37686
上面两句效果一样,只不过第二种是先利用cat将多个java文件的内容合并输出,然后再统计。不过两个都有共同的毛病:连文件里面的空行都给统计进去算作一行了。
去除空行版
find . -name "*.java"|xargs cat|grep -v ^$|wc -l #Output:36335
这个版本靠谱一些了,可以看到去掉空行之后的统计结果变为:36335,比上个版本干掉了1351行的空行。。。但是,Java代码还有注释,还得干掉注释!
去除注释版
# exclude the lines begin with //
find . -name "*.java"|xargs cat|grep -v -e ^$ -e ^\s*\/\/.*$|wc -l #Output:36068
好,这个方法发现,以//
开头的注释有36335-36068=267行。这里需要注意的是,注释行未必就以//
作为开头,可能N个空格之后才开始的//
,所以匹配时需要加上上面的^\s*
放在开头。
大功告成啦?扯淡!!!Java里面注释好几种风格,再给你看看这个非常常见的注释,还是会在统计结果里面
/**
* @author Joe.Ye 2013-6-03 下午3:19:47
*/
简单粗暴的方法但是可以在上面grep的参数里面再加入3个正则,分别去除以/**
、*
、*/
开头的行。
Linux中wc命令用法
Linux系统中的wc(Word Count)命令的功能为统计指定文件中的字节数、字数、行数,并将统计结果显示输出。
命令格式
wc [选项]文件...
命令功能
统计指定文件中的字节数、字数、行数,并将统计结果显示输出。该命令统计指定文件中的字节数、字数、行数。如果没有给出文件名,则从标准输入读取。wc同时也给出所指定文件的总统计数。
命令参数
-c
统计字节数-l
统计行数-m
统计字符数。这个标志不能与 -c 标志一起使用-w
统计字数。一个字被定义为由空白、跳格或换行字符分隔的字符串-L
打印最长行的长度-help
显示帮助信息--version
显示版本信息
版权声明:
作者:Joe.Ye
链接:https://www.appblog.cn/index.php/2023/02/24/shell-command-to-count-code-lines/
来源:APP全栈技术分享
文章版权归作者所有,未经允许请勿转载。
共有 0 条评论