如何在一行中打印grep -o
的输出?我正在尝试打印:
$ echo "Hello Guys!" |grep -E '[A-Z]'
Hello Guys!
$ echo "Hello Guys!" |grep -Eo '[A-Z]' <----Multiple lines
H
G
$ echo "Hello Guys!" |grep -Eo '[A-Z]'
期望的输出:
HG
我可以使用以下命令以低成本实现它,但问题是字母数(在这种情况下为3)可能是动态的。所以这种方法不能使用。
echo "HEllo Guys!" |grep -oE '[A-Z]' |xargs -L3 |sed 's/ //g'
HEG
答案 0 :(得分:4)
您可以使用此 sed 指令
完成所有操作echo "Hello Guys!" |sed 's/[^A-Z]//g'
<强>更新强>
sed命令的细分:
s /// 是 sed 的替代命令。它只是将第一个RegEx(第一个和第二个斜杠之间的一个)替换为斜杠2和3之间的表达式。尾随 g 代表全局,即对当前行中RegEx的每个匹配执行此操作。如果没有 g ,它将在第一场比赛后停止处理。 RegEx本身匹配任何非大写字母,然后这些字母被替换为空,即有效删除。
答案 1 :(得分:3)
您可以使用 awk :
echo "Hello Guys!" | awk '{ gsub(/[^A-Z]/,"", $0); print;}'
HG
还有 tr :
echo "Hello Guys!" | tr -cd [:upper:]
HG
还有 sed :
echo "Hello Guys!" | sed 's/[^\[:upper:]]//g'
HG
答案 2 :(得分:2)
您只需删除换行符即可。您可以使用tr
:
echo "HEllo Guys!" |grep -Eo '[A-Z]' |tr -d '\n'
HEG
虽然,它也削减了最后一个换行符。
答案 3 :(得分:1)
您可以使用perl而不是grep
Australia
France