繁体   English   中英

Bash用变量替换字符串中的第N个单词

[英]Bash replace Nth word in a string with a variable

我需要在字符串(以空格分隔)中找到第N个单词,并用一个变量替换。 在下面的示例中,第四个单词需要用另一个字符串替换。

1 Test 123456 REPLACE_ME 99

1 Test 123456 $STRING_TO_REPLACE 99

我能够使用awk '{ print $4}'找到第四个单词,但不知道如何用另一个字符串变量替换。

任何帮助都感激不尽。

   replace='replace me'; echo "233131 2 saad four five dssd sdad" |  awk -v r="$replace" '{ for(i = 1; i <= NF; i++) { if ( i == 4 )print r;else print $i } }'

使用awk

str="1 Test 123456 REPLACE_ME 99"
STRING_TO_REPLACE="Hello"

echo $str |awk -v r=${STRING_TO_REPLACE} '{$4=r}1'

这是两个外壳解决方案。 第一个是纯sh解决方案:

set -- 1 Test 123456 REPLACE_ME 99
one=$1
two=$2
three=$3
shift 4
echo $one $two $three '$STRING_TO_REPLACE' $*

输出为:

1 Test 123456 $STRING_TO_REPLACE 99

第二个是bash解决方案:

set -- 1 Test 123456 REPLACE_ME 99
echo ${*:1:3} '$STRING_TO_REPLACE' ${*:5:$#}

输出:

1 Test 123456 $STRING_TO_REPLACE 99

如果要替换第N个字,可以这样:

awk -v n=4 -v r="$STRING_TO_REPLACE" '{ $n = r } 1' <<< "$str"

使用GNU sed,您可以这样替换第四个单词:

str="1 Test 123456 REPLACE_ME 99"
STRING_TO_REPLACE="Hello"
sed -e "s/\<\w\+/STRING_TO_REPLACE/4" <<< "$str"

那里的模式意味着:

  • \\< -词的开头
  • \\w “文字字符”
  • \\+ -上一场比赛中的一项或多项
  • \\w\\+ -一个或多个单词字符
  • s///4 4s///4表示仅对第4个事件进行替换

另一种纯sh(可能是bash)解决方案

set -- 1 Test 123456 REPLACE_ME 99
set -- "${@:0:4}" SOMETHING_ELSE "${@:5}"

如果你有露比

# echo "1 Test 123456 REPLACE_ME 99" | ruby -e 'f=gets.split(/\s+/);f[3]="new";puts f.join(" ")'
1 Test 123456 new 99

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM