这篇文章主要介绍“Shell脚本怎么实现C语言代码行数统计”,在日常操作中,相信很多人在Shell脚本怎么实现C语言代码行数统计问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Shell脚本怎么实现C语言代码行数统计”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
写了一个比较粗糙的C语言代码行数统计脚本,目前还有些bug,而且效率也不高。脚本主要就是去除大部分的注释后统计行数,相当于做了一部分预处理的工作。下面是代码:
#!/bin/bash filename=$1echo "`whoami`"if [ $# -lt 1 ];then echo "usage : ./scripts filename" exit -1fiif [ ! -f $filename ];then echo "$filename is not a file" exit 0;fi user="`whoami`"if [ "$user" != "root" ];then echo "use scripts with root" exit 0;fi#删除空行,空行包括:tables + spacesed '/^[[:blank:]]*$/d' $filename > "${filename}_backup"#删除 // 所在的行sed -i '/^[[:blank:]]*\/\//d' "${filename}_backup"##打印[*]' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "start.txt"#打印*/所有的结束行grep -n '[*]/[[:blank:]]*' "${filename}_backup" | awk 'BEGIN{FS=":"}{print $1}' > "end.txt"#合并两个文件,final.txt里面每行就是这种类型注释的开始行和起始行号paste "start.txt" "end.txt" > "final.txt"while read linedo #得到起始行 START=`echo "$line" | awk 'BEGIN{FS="\t"}{print $1}'` #得到结束行 END=`echo "$line" | awk 'BEGIN{FS="\t"}{print $2}'` #这里有一个bug,如是中的在同一行出现,并且有代码也在同一行 # printf("hello world\n"); # #上面两种情况的就没法判断,希望大家优化 if [ $START -eq $END ];then continue fi #删除中间所有行 sed -i "${START},${END}d" "${filename}_backup"done < "final.txt"wc -l "${filename}_backup"rm -f "final.txt" "start.txt" "end.txt"
脚本只能实现大概的代码行数的统计,不能做到精确统计!
到此,关于“Shell脚本怎么实现C语言代码行数统计”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!