grep
是一个在文本文件中搜索特定模式的命令行工具
- 基本语法:
grep [options] 'pattern' file_name
- 使用正则表达式进行过滤:
grep -E 'regex_pattern' file_name
或者
egrep 'regex_pattern' file_name
- 使用正则表达式进行过滤,忽略大小写:
grep -iE 'regex_pattern' file_name
或者
egrep -i 'regex_pattern' file_name
- 从多个文件中过滤:
grep -E 'regex_pattern' file1 file2 file3
- 从标准输入(stdin)过滤:
echo "some text" | grep -E 'regex_pattern'
- 递归地从目录中过滤文件:
grep -r -E 'regex_pattern' directory_name
- 显示匹配行的行号:
grep -n -E 'regex_pattern' file_name
- 只显示匹配到的文本:
grep -o -E 'regex_pattern' file_name
下面是一些使用正则表达式的 grep
示例:
- 查找包含数字的行:
grep -E '\d+' file_name
- 查找以大写字母开头的行:
grep -E '^[A-Z]' file_name
- 查找包含至少一个连续的大写字母的行:
grep -E '[A-Z]+' file_name
- 查找包含邮箱地址的行:
grep -E '\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b' file_name
这些示例仅展示了 grep
和正则表达式的一些基本功能。正则表达式有很多高级功能,可以根据需要构建更复杂的模式。