如何使用awk从字符串中删除名称和姓氏之间的空格? 大多数示例都是关于将数据从命令行重定向到awk,但我需要在awk脚本中操作一个字符串。
转换它:
"steve john"
为:
"stevejohn"
我有一个字符串变量,我要求用户在awk脚本中输入。我需要删除空格。
答案 0 :(得分:15)
gsub
是你的朋友。以下命令基本上在目标$0
(整行)上对正则表达式(在本例中为单个空格)进行全局替换,并将其替换为空字符串。
pax> echo "steve john" | awk '{ gsub (" ", "", $0); print}'
stevejohn
您可以使用任何目标,包括用户的一个输入:
pax> awk 'BEGIN {getline xyzzy ; gsub(" ","", xyzzy) ; print xyzzy}'
hello there my name is pax
hellotheremynameispax
答案 1 :(得分:4)
使用sed
:
$ echo "steve john" | sed 's/ //g'
stevejohn
如果您必须使用awk
,请执行以下操作:
$ echo "steve john" | gawk '{print $1 $2}'
stevejohn
修改强>
在bash脚本中,您可以这样做:
s="steve john" # user input
t=$(echo $s | gawk '{print $1 $2}')
echo $t
答案 2 :(得分:1)
echo "john smith aaa " |\
awk 'BEGIN {FS=" "; OFS=""} {for(i=1;i<=NF;++i) {out = out OFS $i}} END {print out;}'