Linux grep (global regular expression) 命令用于查找文件里符合条件的字符串或正则表达式。grep 指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设 grep 指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为 -,则 grep 指令会从标准输入设备读取数据。
Linux命令行工具中的grep和wc命令是一个非常强大的组合,可以用于在文件集合中搜索匹配特定模式的行并计算匹配行数。
常见用法:
# 查找某文件夹下所有文件中某个字符的个数
grep 'xxx' * | wc -l
# 查看某文件夹下文件的个数
ls -l |grep "^-"|wc -l
# 或
find ./company -type f | wc -l
# 查看某文件夹下文件的个数,包括子文件夹里的。
ls -lR|grep "^-"|wc -l
# 查看某文件夹下文件夹的个数,包括子文件夹里的。
ls -lR|grep "^d"|wc -l
以上内容说明如下:
ls -l
长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等)
grep "^-"
这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d
wc -l
统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于一行信息对应一个文件,所以也就是文件的个数。
下面举几个详细的例子来说明这个组合的用法。
例1:搜索文件中包含特定字符串的行数
假设我们有一个包含一些文本文件的目录,我们想要知道每个文件中包含特定字符串的行数。我们可以使用以下命令:
grep -r "search_string" ./ | wc -l
这个命令会递归地搜索当前目录下的所有文件,查找包含"search_string"的行,并使用wc命令计算匹配的行数。输出结果将显示每个文件中匹配的行数。
例2:搜索文件中不包含特定字符串的行数
有时候我们可能想要搜索文件中不包含特定字符串的行数。这可以通过使用grep命令的-v选项来实现。例如:
grep -v "exclude_string" * | wc -l
递归搜索当前目录下的所有文件,查找不包含"exclude_string"的行,并计算匹配的行数。输出结果将显示所有文件中不包含"exclude_string"的行数。
例3:搜索文件中包含特定模式的行数
除了搜索具体的字符串,我们还可以使用正则表达式来搜索匹配特定模式的行。例如:
grep -E "pattern1|pattern2" * | wc -l
递归搜索当前目录下的所有文件,查找匹配"pattern1"或"pattern2"的行,并计算匹配的行数。输出结果将显示所有文件中匹配模式的行数。
这些例子只是grep和wc命令组合的一小部分用法。通过结合不同的选项和参数,我们可以实现更复杂的搜索和计数任务。
下面再举几个更复杂的例子来说明grep和wc命令的组合用法。
例4:搜索文件中匹配多个关键字的行数
如果我们想要搜索文件中同时匹配多个关键字的行数,我们可以使用grep命令的-E选项来实现多个选项间的逻辑“AND”关系。例如:
grep -E "keyword1|keyword2|keyword3" * | wc -l
递归搜索当前目录下的所有文件,查找同时包含"keyword1"、"keyword2"和"keyword3"的所有行,并计算匹配的行数。输出结果将显示所有文件中同时匹配所有关键字的行数。
例5:搜索文件中匹配模式的行并重定向到指定文件
我们可以将grep命令的输出重定向到指定文件中,以便将匹配的行保存到文件中进行进一步处理。例如:
grep "search_string" ./ | wc -l > output.txt
递归搜索当前目录下的所有文件,查找包含"search_string"的行,并使用wc命令计算匹配的行数。然后,将输出结果重定向到名为"output.txt"的文件中。
例6:搜索文件中匹配模式的行并输出匹配行的行号
我们可以使用grep命令的-n选项来输出匹配行的行号。例如:
grep -n "search_string" ./
递归搜索当前目录下的所有文件,查找包含"search_string"的行,并输出匹配行的行号。
这些例子展示了grep和wc命令组合的更多用法和功能。根据不同的需求,我们可以灵活运用这些选项和参数来满足特定的搜索和计数任务。