我必须在文件的倒数第二行 – file.txt中用“string”替换“pattern”.
以下三个sed命令能够打印倒数第二行.但我需要用“字符串”替换“模式”.任何帮助?
sed -e '$!{h;d;}' -e x file.txt
sed -n 'x;$p' file.txt
sed 'x;$!d' file.txt
$cat file.txt
cabbage
spinach
collard greens
corn salad
Sweet pepper
kale
如何替换文件的倒数第二行(甜椒):
一个.如果倒数第二行包含“甜椒”,则将“Sweet”替换为“green”
湾用“胡萝卜”代替整条生产线,无论它含有什么
要在第二行到最后一行将Sweet更改为Green,但仅当该行包含Sweet pepper时:
$sed 'x; ${/Sweet pepper/s/Sweet/Green/;p;x}; 1d' file.txt
cabbage
spinach
collard greens
corn salad
Green pepper
kale
要将整个倒数第二行替换为胡萝卜,无论它包含什么,
$sed 'x; ${s/.*/carrots/;p;x}; 1d' file.txt
cabbage
spinach
collard greens
corn salad
carrots
kale
这个怎么运作
让我们使用此命令并一次检查一步:
sed 'x; ${s/.*/carrots/;p;x}; 1d'
> x
这将交换模式空间(保存最近读取的行)和保持空间.
完成此操作后,保留空间将包含最近读取的行,并且模式空间将包含上一行.
(例外情况是我们刚读完第一行.在这种情况下,保留空间将有第一行,模式空间将为空.)
> ${s /.*/ carrots /; p; x}
当我们在最后一行(由$表示)时,模式空间保持倒数第二行,我们可以执行我们喜欢的任何替换或其他命令.当我们完成后,我们用p打印倒数第二行.最后,我们用x交换模式并再次保持空间,以便模式空间将再次包含最后一行. sed将打印这个,因为默认情况下,在命令的末尾,sed打印模式空间中的任何内容.
> 1d
当我们在第一行(由1表示)时,模式空间为空(因为没有前一行)并且我们将其删除(d).
一种更简单的方法
这种方法易于理解,代价是执行速度较慢:
$tac file.txt | sed '2 {/Sweet pepper/s/Sweet/Green/}' | tac
cabbage
spinach
collard greens
corn salad
Green pepper
kale
并且,对于胡萝卜:
$tac file.txt | sed '2 s/.*/carrots/' | tac
cabbage
spinach
collard greens
corn salad
carrots
kale
它是如何工作的:在这里,我们使用tac来反转线的顺序.注意:
$tac file.txt
kale
Sweet pepper
corn salad
collard greens
spinach
cabbage
通过这种方式,倒数第二行成为第2行.因此,我们只是简单地告诉sed在第2行操作.之后,我们再次使用tac来放置行,但顺序正确.