标签:匹配 正则表达式 word file Linux grep line
Linux grep命令
grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来,它的使用权限是所有用户。
格式
grep [options]
主要参数
[options]主要参数:
-
-c:只输出匹配的行数。
-
-i:不区分大小写。
-
-h:查询多文件时不显示文件名。
-
-l:查询多文件时只输出包含匹配字符的文件名。
-
-n:显示匹配行及行号。
-
-s:不显示不存在或无匹配文本的错误信息。
-
-v:显示不包含匹配文本的所有行。
pattern正则表达式主要参数:
-
\:忽略正则表达式中特殊字符的原有含义。
-
^:匹配正则表达式的开始行。
-
$:匹配正则表达式的结束行。
-
\ <:从匹配正则表达式的行开始。
-
\ >:从匹配正则表达式的行结束。
-
[ ] :单个字符,如[A] 即A符合要求。
-
[ - ]:范围,如[A-Z],即A、B、C一直到Z都符合要求。
-
。:所有单个字符。
- *有字符,长度可以为0。
grep命令常见用法
- 在文件中搜索一个单词:
grep word file_name
grep "word" file_name
- 在多个文件中查找:
grep "word" fille_1 file_2 file_3
- 输出除了word的所有行:
greo -v "word" file_name
- 标记匹配颜色:
grep "word" file_name --color=auto
- 使用正则表达式-E选项:
grep -E "[1-9]+"
或
egrep "[1-9]+"
- 只输出文件中匹配到的部分-o选项:
echo this is a test line.|grep -o -E "[a-z]+\ ."
line.
echo this is a test line. |egrep -o [a-z]+\ ."
line.
- 搜索多个文件并查找匹配文本在那些文件中:
grep -l "test" file1 file2
- 在多级目录中对文本进行递归搜索:
grep "test" . -r -n
. 表示当前目录
- 忽略匹配样式中的字符大小写:
echo "hello word"|grep -i "HELLO"
hello
- 选项-e 制动多个匹配样式:
echo this a test line|grep -e "is" -e "line" -o
is
line
标签:匹配,正则表达式,word,file,Linux,grep,line 来源: https://blog.51cto.com/13939728/2481720
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。