匹配文件中的字符串并使用sed或awk打印整个值

时间:2015-01-28 13:04:53

标签: regex bash shell awk sed

我正在尝试提取与字符串相关的值,但需要一种最佳方式。

name=sandeep login_name=sn003 version=3.0 rel_no=456....

以上文字存储在一个文件中 我正在尝试搜索字符串的一部分,然后打印整个值。

说我需要使用login进行搜索,输出应为

login_name=sn003

我已经尝试过命令

cat filename | awk -F" " '{print $2}'

如果login_name不是第二个字段,则不会打印 如何在任何位置搜索字符串然后打印结果?

提前致谢。

2 个答案:

答案 0 :(得分:2)

你可以使用grep,

$ echo 'name=sandeep login_name=sn003 version=3.0 rel_no=456.....' | grep -o '[^ ]*login[^ ]*'
login_name=sn003

[^ ]*匹配任何字符,但不匹配空格,零次或多次。

OR

通过sed,

$ echo 'name=sandeep login_name=sn003 version=3.0 rel_no=456.....' | sed 's/.*\([^ ]*login[^ ]*\).*/\1/'
login_name=sn003

OR

通过awk,

$ echo 'name=sandeep login_name=sn003 version=3.0 rel_no=456.....' | awk '{for(i=1;i<=NF;i++){if($i~/login/){print $i}}}'
login_name=sn003

答案 1 :(得分:0)

使用perl:

perl -lne 'print $1 if(/(login[\S]+\s).*/)'