如何匹配替换命令的一组特定行?
(不正确的):
sed -e'71,116,211s/[ ]+$//' ...
我想仅删除第71,116和211行的尾随空格
答案 0 :(得分:1)
您可以尝试以下方式:
awk 'NR== 71 || NR == 116 || NR == 211 {sub(/ *$/,"",$0)}{print $0}'
或
sed '71s/ *$//;116s///;211s///'
答案 1 :(得分:1)
sed '71bl;116bl;211bl;b;:l;s/[ ][ ]*$//' input
对于任何指定的行,此脚本将跳转到标签l
。其他行将使用裸branch
跳转到脚本的末尾。
一个awk解决方案:
awk -v k="71,116,221" 'BEGIN{split(k,a,",")}
(NR in a) { sub(/ *$/,"",$0) }1' input
答案 2 :(得分:0)
这可能适合你(GNU sed):
sed -r '/\s+$/!b;71s///;116s///;221s///' file
或者也许:
sed -e '/ *$/!b' -e '71s///' -e '116s///' -e '221s///' file
或者已经说过:
sed -e '71ba' -e '116ba' -e '221ba' -e 'b' -e ':a' -e 's/ *$//' file