Skip to content
Michael Diamond edited this page Apr 23, 2020 · 7 revisions

Consider using grep -c instead of grep|wc.

Problematic code:

grep foo | wc -l

Correct code:

grep -c foo

For multiple files

Instead of:

grep foo *.log | wc -l

Pipe all the file contents into grep (passing the files directly to grep causes -c to print each file's count separately, rather than the total):

cat *.log | grep foo -c

Rationale:

This is purely a stylistic issue. grep can count lines without piping to wc.

Note that in many cases, this number is only used to see whether there are matches (i.e. == 0). In these cases, it's better and more efficient to use grep -q and check its exit status:

if grep -q pattern file
then
  echo "The file contains the pattern"
fi

Also note that in foo | grep bar | wc -l, wc will mask the exit code of grep by default (i.e. without set -o pipefail), and always return success. If replacing with foo | grep -c bar, grep will exit non-zero when the count is 0. This is convenient for conditional statements but may require handling when used with set -e.

Exceptions

If you e.g. want to count characters instead of lines, and you actually care about the number and not just whether it's greater than 0, you can ignore this error.

ShellCheck

Each individual ShellCheck warning has its own wiki page like SC1000. Use GitHub Wiki's "Pages" feature above to find a specific one, or see Checks.

Clone this wiki locally