我想知道,如果使用egrep((GNU grep)2.5.1),我可以选择匹配文本的一部分,例如:
grep '^([a-zA-Z.-]+)[0-9]+' ./file.txt
Run Code Online (Sandbox Code Playgroud)
所以我只得到括号之间匹配的部分
house.com
Run Code Online (Sandbox Code Playgroud)
而不是像我通常得到的整条线:
house.com112
Run Code Online (Sandbox Code Playgroud)
假设我的file.txt中有一行house.com112.
(实际上这个正则表达式只是一个例子,我只想知道我是否只能打印整行的一部分.)
我知道在某些语言中,例如PHP,Perl甚至AWK我都可以,但我不知道我是否可以使用egrep.
先感谢您!
Mar*_*ers 10
用于sed在grep找到匹配的行后修改结果:
grep '^[a-zA-Z.-]+[0-9]+' ./file.txt | sed 's/[0-9]\+$//'
Run Code Online (Sandbox Code Playgroud)
或者如果你只想坚持使用grep,你可以使用grep和-o开关而不是sed:
grep '^[a-zA-Z.-]+[0-9]+' ./file.txt | grep -o '[a-zA-Z.-]+'
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
11016 次 |
| 最近记录: |