My input: ps -ef|grep mysql
--defaults-file=/xyz/ --basedir=name --datadir=/data --user=abc--log-error=/log1 --port=1211
--defaults-file=/mno/ --basedir=anothername --datadir=/data2 --user=pqr --log-error=/log2 --port=1212
我尝试了以下命令
ps -ef|grep mysql| awk 'BEGIN {RS=" "}; /--port/'
output:
--port=1211
--port=1212
如何使用单个awk命令获取特定的密钥评估者对?输出应该是这样
port:1211
base dir:name
log dir:log1
port:1212
base dir:anothername
log dir:log2
答案 0 :(得分:0)
不确定您的sed版本,请尝试以下操作:
sed -e '/port=/{' -e 'h;s/.*--port=\([0-9]*\)\s*$/port:\1/;x;s/.*--basedir=\([^ ]*\).*--log-error=.\([^ ]*\).*/base dir:\1\nlog dir:\2\n/;H;x}'
--posix
测试正常。