在庆典,如何计量非空白的代码行一个项目?

有帮助吗?

解决方案

cat foo.c | sed '/^\s*$/d' | wc -l

如果您考虑注释空白行:

cat foo.pl | sed '/^\s*#/d;/^\s*$/d' | wc -l

虽然,这取决于语言。

其他提示

#!/bin/bash
find . -path './pma' -prune -o -path './blog' -prune -o -path './punbb' -prune -o -path './js/3rdparty' -prune -o -print | egrep '\.php|\.as|\.sql|\.css|\.js' | grep -v '\.svn' | xargs cat | sed '/^\s*$/d' | wc -l

以上内容将为您提供项目代码行(删除空行)的总计数(当前文件夹和所有子文件夹递归)。

在上面的“./ blog”中。 " ./的PunBB" " ./ JS /的3rdParty"和“./ pma”是我黑名单的文件夹,因为我没有在其中编写代码。此外,.php,.as,.sql,.css,.js是正在查看的文件的扩展名。任何具有不同扩展名的文件都将被忽略。

如果您想使用shell脚本以外的其他内容,请尝试 CLOC

  

cloc计算空白行,评论   线和物理线   许多编程语言中的代码。它   完全用Perl编写,没有   标准之外的依赖关系   Perl v5.6及更高版本的分布   (来自某些外部模块的代码是   嵌入在cloc中)等等   便携式的。

使用常见的shell实用程序有很多方法可以做到这一点。

我的解决方案是:

grep -cve '^\s*

这会搜索< file>中的行。不匹配(-v)匹配模式(-e)'^ \ s * $'的行,它是一行的开头,后跟0或更多的空白字符,后跟一行的结尾(即。除了空白之外没有其他内容),并显示匹配行数(-c)而不是匹配行本身。

此方法优于涉及到 wc 的方法的一个优点是,您可以指定多个文件并为每个文件获取单独的计数:

$ grep -cve '^\s* <file>

这会搜索&lt; file&gt;中的行。不匹配(-v)匹配模式(-e)'^ \ s * $'的行,它是一行的开头,后跟0或更多的空白字符,后跟一行的结尾(即。除了空白之外没有其他内容),并显示匹配行数(-c)而不是匹配行本身。

此方法优于涉及到 wc 的方法的一个优点是,您可以指定多个文件并为每个文件获取单独的计数:

<*> *.hh config.hh:36 exceptions.hh:48 layer.hh:52 main.hh:39
<file>

这会搜索&lt; file&gt;中的行。不匹配(-v)匹配模式(-e)'^ \ s * $'的行,它是一行的开头,后跟0或更多的空白字符,后跟一行的结尾(即。除了空白之外没有其他内容),并显示匹配行数(-c)而不是匹配行本身。

此方法优于涉及到 wc 的方法的一个优点是,您可以指定多个文件并为每个文件获取单独的计数:

<*>

'wc'对行,单词,字符进行计数,因此要计算所有行(包括空行),请使用:

wc *.py

要过滤掉空白行,您可以使用grep:

grep -v '^\s*

' - v'告诉grep输出除匹配之外的所有行 '^'是一行的开头 '\ s *'是零个或多个空格字符 '$'是一条线的终点 * .py是我想要计算的所有文件的示例(当前目录中的所有python文件) 管道输出到wc。你离开了。

我正在回答我自己的(真实的)问题。找不到覆盖此内容的stackoverflow条目。

*.py | wc

' - v'告诉grep输出除匹配之外的所有行 '^'是一行的开头 '\ s *'是零个或多个空格字符 '$'是一条线的终点 * .py是我想要计算的所有文件的示例(当前目录中的所有python文件) 管道输出到wc。你离开了。

我正在回答我自己的(真实的)问题。找不到覆盖此内容的stackoverflow条目。

这个命令的数量的非空行。
cat fileName | grep -v ^$ | wc -l
查询-v^$经常表达的功能忽视空行。

cat 'filename' | grep '[^ ]' | wc -l

应该做的很好

grep -cvE '(^\s*[/*])|(^\s*$)' foo

-c = count
-v = exclude
-E = extended regex
'(comment lines) OR (empty lines)'
where
^    = beginning of the line
\s   = whitespace
*    = any number of previous characters or none
[/*] = either / or *
|    = OR
$    = end of the line

我发布这个因为其他选项给了我错误的答案。这适用于我的java源代码,其中注释行以/或*开头(我在多行注释中的每一行都使用*)。

awk '/^[[:space:]]*$/ {++x} END {print x}' "$testfile"

这是一个Bash脚本,用于计算项目中的代码行数。它以递归方式遍历源树,并且不包括使用“//”的空白行和单行注释。

# $excluded is a regex for paths to exclude from line counting
excluded="spec\|node_modules\|README\|lib\|docs\|csv\|XLS\|json\|png"

countLines(){
  # $total is the total lines of code counted
  total=0
  # -mindepth exclues the current directory (".")
  for file in `find . -mindepth 1 -name "*.*" |grep -v "$excluded"`; do
    # First sed: only count lines of code that are not commented with //
    # Second sed: don't count blank lines
    # $numLines is the lines of code
    numLines=`cat $file | sed '/\/\//d' | sed '/^\s*$/d' | wc -l`

    # To exclude only blank lines and count comment lines, uncomment this:
    #numLines=`cat $file | sed '/^\s*$/d' | wc -l`

    total=$(($total + $numLines))
    echo "  " $numLines $file
  done
  echo "  " $total in total
}

echo Source code files:
countLines
echo Unit tests:
cd spec
countLines

以下是我的项目的输出结果:

Source code files:
   2 ./buildDocs.sh
   24 ./countLines.sh
   15 ./css/dashboard.css
   53 ./data/un_population/provenance/preprocess.js
   19 ./index.html
   5 ./server/server.js
   2 ./server/startServer.sh
   24 ./SpecRunner.html
   34 ./src/computeLayout.js
   60 ./src/configDiff.js
   18 ./src/dashboardMirror.js
   37 ./src/dashboardScaffold.js
   14 ./src/data.js
   68 ./src/dummyVis.js
   27 ./src/layout.js
   28 ./src/links.js
   5 ./src/main.js
   52 ./src/processActions.js
   86 ./src/timeline.js
   73 ./src/udc.js
   18 ./src/wire.js
   664 in total
Unit tests:
   230 ./ComputeLayoutSpec.js
   134 ./ConfigDiffSpec.js
   134 ./ProcessActionsSpec.js
   84 ./UDCSpec.js
   149 ./WireSpec.js
   731 in total

享受! - Curran

这有点取决于您在项目中拥有的文件数量。从理论上讲,你可以使用

grep -c '.' <list of files>

您可以使用查找实用程序填写文件列表。

grep -c '.' `find -type f`

会为每个文件提供行数。

脚本以递归方式计算当前目录中具有特定文件扩展名的所有非空行:

#!/usr/bin/env bash
(
echo 0;
for ext in "$@"; do
    for i in $(find . -name "*$ext"); do
        sed '/^\s*$/d' $i | wc -l ## skip blank lines
        #cat $i | wc -l; ## count all lines
        echo +;
    done
done
echo p q;
) | dc;

样本用法:

./countlines.sh .py .java .html

如果您希望整个项目中给定文件扩展名的所有文件的所有非空行的总和:

while read line
do grep -cve '^\s*

第一个arg是项目的基本目录,第二个是文件扩展名。样品用法:

./scriptname ~/Dropbox/project/src java

它只是以前解决方案的集合。

"$line" done < <(find $1 -name "*.$2" -print) | awk '{s+=$1} END {print s}'

第一个arg是项目的基本目录,第二个是文件扩展名。样品用法:

<*>

它只是以前解决方案的集合。

grep -v '^\W*

给出当前目录及其子目录中所有文件的聚合计数。

HTH!

`find -type f` | grep -c '.' > /path/to/lineCountFile.txt

给出当前目录及其子目录中所有文件的聚合计数。

HTH!

这给出了不计算空行的行数:

grep -v ^$ filename wc -l | sed -e 's/ //g' 
rgrep . | wc -l

给出当前工作目录中非空行的计数。

在linux上已有一个名为'wc'的程序。

只需

wc -l *.c 

它会为您提供每个文件的总行数和行数。

许可以下: CC-BY-SA归因
不隶属于 StackOverflow
scroll top