使用awk获取特定的字符串

时间:2014-11-26 15:59:05

标签: linux bash awk sed ps

我有一个包含ps输出中的多个字符串的java进程。我只想要一个特定的字符串。

例如,我有

root 5565 7687  0 Nov20 ?  00:00:54 /bin/java -Xms256m -Xmx512m -XX:MaxPermSize=128m  -XX:PermSize=256m -XX:MaxPermSize=256m -Dstdout.file=/tmp/std.out -da -Dext.dir.class=profiles/ -Dprocess.name=java1 -Djava.security.policy=security.policy

我只想要process.name=java1,并且ps输出中不需要任何其他内容。我无法使用awk或sed找到一种切实可行的方法。

我尝试使用:

ps -ef | grep java1 | grep -v grep | awk '/process.name/ {print $0}'

我得到的输出是ps -ef输出。

有更简单的方法吗?

5 个答案:

答案 0 :(得分:2)

这是一种方式:

ps -ef | awk -F"process.name" '{split($2,a," ");print FS a[1]}'
process.name=java1

答案 1 :(得分:1)

有一种更简单的方法:使用grep -o

ps -ef | grep -o 'process.name=java1'

然而,这只会输出字符串" process.name = java1" (可能多次,每次进程一次)对我来说似乎有点无意义。你真的想做什么?

答案 2 :(得分:0)

尝试这样做:

ps -ef | grep -o 'process\.name=[a-z0-9]\+'

答案 3 :(得分:0)

使用gnu-awk

ps -ef | awk -v s='process.name=' 'BEGIN{RS=s} !RT{print s $0}'
process.name=java1 -Djava.security.policy=security.policy

答案 4 :(得分:0)

这可能是你想要的,但没有更多的样本输入(ps -ef输出),并且在=符号之后更好地描述你想要匹配的东西,它只是一个猜测:

$ sed -r 's#.*[[:space:]]+-D(process\.name=[^[:space:]]+).*#\1#' file
process.name=java1