166

Bash で、プロジェクト内の空白以外のコード行の数をカウントするにはどうすればよいですか?

4

20 に答える 20

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

また、コメントの空白行を考慮すると、次のようになります。

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

ただし、それは言語に依存します。

于 2008-09-22T13:23:10.327 に答える
55
#!/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は、調べているファイルの拡張子です。拡張子が異なるファイルはすべて無視されます。

于 2008-09-22T13:28:48.550 に答える
39

シェルスクリプト以外のものを使いたい場合は、CLOCを試してください:

cloc は、多くのプログラミング言語でソース コードの空白行、コメント行、および物理行をカウントします。これは完全に Perl で書かれており、Perl v5.6 以降の標準ディストリビューション以外の依存関係はなく (いくつかの外部モジュールからのコードは cloc に組み込まれています)、移植性が非常に高いです。

于 2008-09-22T13:25:43.910 に答える
38

これを行うには、一般的なシェル ユーティリティを使用する多くの方法があります。

私の解決策は次のとおりです。

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

これは <file> 内の行を検索し、パターン (-e) '^\s*$' に一致する一致しない (-v) 行と、その後に 0 個以上の空白文字が続く行を検索します。一致する行自体の代わりに、一致する行の数を表示します (-c)。

へのパイプを伴う方法に対するこの方法の利点は、wc複数のファイルを指定して、各ファイルの個別のカウントを取得できることです。

$ grep -cve '^\s*$' *.hh

config.hh:36
exceptions.hh:48
layer.hh:52
main.hh:39
于 2008-09-22T13:27:42.017 に答える
19

このコマンドは、非空白行の数をカウントします。
cat fileName | grep -v ^$ | wc -l
grep -v ^$ 正規表現関数は空白行を無視します。

于 2014-06-04T09:51:04.147 に答える
14

「wc」は行、単語、文字をカウントするため、すべての行 (空白行を含む) をカウントするには、次を使用します。

wc *.py

空白行を除外するには、grep を使用できます。

grep -v '^\s*$' *.py | wc

'-v' は、一致する行を除くすべての行を出力するように grep に指示します '^' は行頭です '\s*' は 0 個以上の空白文字です '$' は行末です *.py は私の例ですカウントしたいすべてのファイル (現在のディレクトリにあるすべての python ファイル) は、出力を wc にパイプします。どうぞ。

私は自分の(本物の)質問に答えています。これをカバーする stackoverflow エントリが見つかりませんでした。

于 2008-09-22T13:24:30.107 に答える
6
cat 'filename' | grep '[^ ]' | wc -l

うまくトリックを行う必要があります

于 2008-09-22T13:28:15.917 に答える
4
awk '/^[[:space:]]*$/ {++x} END {print x}' "$testfile"
于 2008-09-22T13:23:10.280 に答える
2

プロジェクト内のコードの行数をカウントする 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

楽しみ!--カラン

于 2014-04-01T00:01:52.237 に答える
1

プロジェクトにあるファイルの数に多少依存します。理論的には使用できます

grep -c '.' <list of files>

検索ユーティリティを使用してファイルのリストを入力できる場所。

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

ファイルごとの行数がわかります。

于 2008-09-22T13:28:34.887 に答える
1

現在のディレクトリ内の特定のファイル拡張子を持つすべての非空白行を再帰的にカウントするスクリプト:

#!/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
于 2011-08-14T01:07:44.693 に答える
1

プロジェクト全体で、特定のファイル拡張子を持つすべてのファイルのすべての非空白行の合計が必要な場合:

while read line
do grep -cve '^\s*$' "$line"
done <  <(find $1 -name "*.$2" -print) | awk '{s+=$1} END {print s}'

最初の引数はプロジェクトのベース ディレクトリで、2 番目はファイル拡張子です。使用例:

./scriptname ~/Dropbox/project/src java

これは、以前のソリューションのコレクションにすぎません。

于 2011-12-02T06:56:06.897 に答える
0

これにより、空白行をカウントせずに行数がカウントされます。

grep -v ^$ filename wc -l | sed -e 's/ //g' 
于 2011-02-23T11:56:02.770 に答える
0
rgrep . | wc -l

現在の作業ディレクトリ内の空白でない行の数を示します。

于 2016-12-08T12:43:51.623 に答える
0
grep -v '^\W*$' `find -type f` | grep -c '.' > /path/to/lineCountFile.txt

現在のディレクトリとそのサブディレクトリ内のすべてのファイルの集計数を示します。

チッ!

于 2011-01-03T16:44:59.700 に答える
-3

'wc' と呼ばれる Linux には、このためのプログラムが既にあります。

ただ

wc -l *.c 

合計行と各ファイルの行が表示されます。

于 2012-05-05T02:02:45.507 に答える