正则表达式 – 与egrep正则表达式匹配的部分

我想知道,如果使用egrep((GNU grep)2.5.1),我可以选择匹配文本的一部分,例如:

grep '^([a-zA-Z.-]+)[0-9]+' ./file.txt

所以我只得到括号之间匹配的部分

house.com

而不是像我通常得到的整条线:

house.com112

假设我的file.txt中有一行house.com112.

(实际上这个正则表达式只是一个例子,我只想知道我是否只能打印整行的一部分.)

我知道在某些语言中,例如PHP,Perl甚至AWK我都可以,但我不知道我是否可以使用egrep.

先感谢您!

解决方法

在grep找到匹配的行后使用sed修改结果:

grep '^[a-zA-Z.-]+[0-9]+' ./file.txt | sed 's/[0-9]\+$//'

或者如果你只想坚持使用grep,你可以使用grep和-o开关而不是sed:

grep '^[a-zA-Z.-]+[0-9]+' ./file.txt | grep -o '[a-zA-Z.-]+'

相关文章

jquery.validate使用攻略(表单校验) 目录 jquery.validate...
/\s+/g和/\s/g的区别 正则表达式/\s+/g...
自整理几个jquery.Validate验证正则: 1. 只能输入数字和字母...
this.optional(element)的用法 this.optional(element)是jqu...
jQuery.validate 表单动态验证 实际上jQuery.validate提供了...
自定义验证之这能输入数字(包括小数 负数 ) <script ...