如何删除文件中以特定字符串(在本例中为字符串“end”)开头的所有单词,以便:
<region> sample=PDL UP IN-A-1.flac lokey=21 hikey=21 lovel=0 hivel=21 end=423471 pitch_keycenter=21
<region> sample=PDL UP IN-A-1_0001.flac lokey=21 hikey=21 lovel=22 hivel=42 end=370196 pitch_keycenter=21
<region> sample=PDL UP IN-A-1_0002.flac lokey=21 hikey=21 lovel=43 hivel=63 end=362268 pitch_keycenter=21
变成:
<region> sample=PDL UP IN-A-1.flac lokey=21 hikey=21 lovel=0 hivel=21 pitch_keycenter=21
<region> sample=PDL UP IN-A-1_0001.flac lokey=21 hikey=21 lovel=22 hivel=42 pitch_keycenter=21
<region> sample=PDL UP IN-A-1_0002.flac lokey=21 hikey=21 lovel=43 hivel=63 pitch_keycenter=21
使用命令行
我试过:
sed 's/\S*\(end\|END\)\S*//g' file.txt
但这没有用。
谢谢。
你们非常接近。您缺少的最重要的事情是启用扩展正则表达式。
其次,比赛开始时有“\S*”。这实际上并没有做任何事情,因为它允许在除空格之外的任何内容上进行“一或零”匹配。由于“end”总是以空格开头,因此永远不会使用它。我相信你的意思是说“end”是单词的开头,它是一个“<”字符。
这是一个工作版本:
sed -E 's/\<(end|END)\S*//g' file.txt
但还可以稍微改进一下。在这里,我使匹配大小写不敏感,以删除单词上的“或”,从而消除了对扩展正则表达式的需要。我还添加了一个尾随“\s”来删除尾随空格(防止间隙中出现双空格)。
sed 's/\<END\S*\s//gi' file.txt
这是 GNU 的 sed 指南供参考。
更新
根据您下面的评论,看来我们都误解了您想要的东西。听起来您不仅想删除这些文本字段,而且还想在文件本身中删除这些文本字段。虽然我很抱歉忽略了这一点,但这是一个很好的教训,说明了为什么用措辞表达你的问题以准确地询问你想要的东西是如此重要。
无论如何,您的解决方案(添加> file.txt)有效地用新文本覆盖旧文件。具体来说,sed 会将结果输出到 stdout(您的终端)。“>”符号称为重定向。它将把之前的标准输出重定向到之后的内容。这实际上会删除现有文件并用新文件替换。
虽然这有效,但并不是最好的。如果您想就地替换文件中的字符串,sed 也可以通过添加“-i”选项来为您做到这一点:
sed -i 's/\<END\S*\s//gi' file.txt
这是一个有用的参考,可以帮助有效地表达问题。您越准确地表达您想要的内容,答案就越好!
希望这可以帮助!
在这种情况下,由于输入的格式非常好,因此可能更容易使用
cut
解释
-d" "
将字段分隔符设置为空格。默认为选项卡。-f-8,10-
从第一个字段到第八个字段,然后从最后一个字段取出第十个字段。跳过第九个字段,即以“end”开头的字段。匹配并删除空格,后跟结束或 END,后跟尽可能多的非空格。
这很奇怪!
我尝试了所有不同的建议,但没有任何效果。该文件只是保持不变。
然后,我将 > file1.txt 添加到命令中,以便输出将创建原始文件的新的和编辑过的副本,然后几乎每个建议的代码都可以工作。
我不知道为什么会这样。
无论如何,感谢大家及时有效的答复。