一行shell命令实现代码行数统计

一行命令实现代码行数统计

    1. 基本版
find . -name "*.cpp"|xargs wc -l|grep "total"|awk '{print $1}'  
find . -name "*.cpp"|xargs cat|wc -l   

    2. 去空行版
find . -name "*.java"|xargs cat|grep -v ^$|wc -l

    上面的^$是正则表达式,^是以匹配开头,$是匹配结尾,所以^$是匹配一个空行。

    3. 去注释版
find . -name "*.java"|xargs cat|grep -v -e ^$ -e ^\s*\/\/.*$|wc -l

    上面的^\s*\/\/.*$是正则表达式,其中^\s*表明以空格(多个)开头,\/\/表明是//开头的注释,“.*$”表明可能以“.”结尾

    去注释版只是去掉以//开头的注释,对于以/*  */包含的注释并没有去掉。

     上面是只识别.cpp文件,如果想一次统计多种类型的文件,怎么办呢:

     4.  统计本文件夹下.h,.cpp,.sh三种类型的文件代码行数
    方式一:     
 find -name "*[.h|.cpp|.sh]" -type f | xargs cat | wc -l
    方式二:
find -name "*[.h|.cpp|.sh]" -type f -exec cat {} \; | wc -l
    方式三:
find -regex ".*\.h\|.*\.cpp\|.*\.sh" | xargs cat |wc -l
    
    其实上面三种方法的区别就是find到所有的目标文件的方法,还有下面两种方法可以找到想要的结果。

    方法四:
find -name "*[.h|.cpp|.sh]" ! -name "."
    上面!号前半部分找出会包含"."这个目录,用"!"排除这个目录,当然了,这个和上面方式一,二中的-type f是相近似的方法,-type f是指定目标类型为文件。
    方法五:最笨的方法:
find -name "*.h" -o -name "*.sh" -o -name "*.cpp"


    此外,如果当前目录下包含子目录,则一并会被find出来,如果不想find子目录,则可以用-maxdepth选项:     
find -maxdepth 1 -name "*[.h|.cpp|.sh]" -type f







你可能感兴趣的:(Linux,Shell)