2014-10-03 84 views
3

我试图提取device_uuid之间的字符串:和眼前利益,提取文本

d

device_uuid:xxx,yyy,ttt 
device_uuid:2,ppp,hhh 

代码:

$ sed -e 's/device_uuid:\(.*\),/\1/' d 
xxx,yyyttt 
2,ppphhh 

预期o/p:

xxx 
2 

编辑1:

不能使用的grep -OP由于我在AIX

使用AWK失败:

d

device_uuid:xxx,yyy,ttt 
ptr,ttt 
device_uuid:2,ppp,hhh 
total_uuid:5,jkl,mno 
device_uuid:9 

$ awk -F 'total_uuid:|,' '{print $2}' d 
yyy 
ttt 
ppp 
5 

预期○在上述情况下/ P:

blank or device_uuid:xxx,yyy,ttt 
blank or ptr,ttt 
blank or device_uuid:2,ppp,hhh 
5 
blank or device_uuid:9 

device_uuid:不必是第一列,就像明智的一切都可以是随机的,但我需要选择变量对应的值直到立即分隔符,

- 剪切也失败,因为它只能接受一个字符分隔符。

- $ perl -l -ne '/device_uuid:([\w\-]*?)\,/g and print($1)' d

以上的perl也失败,因为,如果device_uuid不存在于一条线则该线在O/P删除,但应 显示为空白

由于。

回答

1

使用sed

sed 's/^.*total_uuid:\([^,]*\).*$/\1/' file 
device_uuid:xxx,yyy,ttt 
ptr,ttt 
device_uuid:2,ppp,hhh 
5 
device_uuid:9 

使用grep -oP

grep -oP 'device_uuid:\K[^,]+' file 
xxx 
2 
+0

如何在AIX中使用-oP?它不支持这些选项? – user2711819 2014-10-03 19:59:46

+0

那么你没有提到有问题的AIX。无论如何,你可以使用我的awk命令。 – anubhava 2014-10-03 20:00:53

+0

已更新问题 – user2711819 2014-10-03 20:10:03

0

这是不漂亮,但一对夫妇的cut S的关系做的工作:

$ echo "device_uuid:xxx,yyy,ttt" | cut -d":" -f2- | cut -d"," -f1 
xxx 
+0

$ echo“device_uuid:xxx,yyy,ttt”| cut -d“device_uuid:”-f2- |剪切-d“,”-f1 evice_uuid:xxx - 我不能单独分隔: – user2711819 2014-10-03 19:43:28

+0

更新问题 – user2711819 2014-10-03 20:10:31