gpt4 book ai didi

linux - 使用 "sed"命令时遇到问题?

转载 作者:太空宇宙 更新时间:2023-11-04 04:42:27 26 4
gpt4 key购买 nike

我想使用 sed 在 .txt 文件的每一行末尾添加逗号 (,)。我使用了这个 sed 命令:

sed 's/$/,/' 

但不是给我这个输出:

27,
2,

...

30,

它显示了这个:

35
,
1
,

...

15
,

也就是说,它将每个逗号添加到一个新行中。我该如何解决这个问题?

另外,我可以使用什么命令删除包含三位数或以非数字结尾的行的最后一个字符?

还有一个问题:如果我想使用 for 循环在目录中的所有文本文件上运行代码,那么我是否必须制作 bash 脚本?

最佳答案

I would like to use sed to add a comma (,) at the end of each line of my .txt file.

你原来的sed命令对我有用,因为你似乎想要一个包含一系列一位和两位数字的文本文件,一个到一行:

$ sed 's/$/,/' <<EOF
1
17
99
0
23
EOF
1,
17,
99,
0,
23,

您的文件可能具有非标准行终止符(例如 Windows 行终止符),但在我的环境中,使用 GNU sed v4.2.2,会产生与您描述的行为不同的不良行为。尽管如此,在输入上运行 dos2unix 和/或验证它不包含任何意外的非打印字符也没什么坏处。

但如果你愿意

to remove the last character of those lines that contain three-digit numbers or end with non-digits?

在相同的文件上那么这是没有意义的,因为可能需要采用完全不同的方法,可能是这样的:

sed 's/^\([0-9]\{1,2\}\).*/\1,/'

示例:

$ sed 's/^\([0-9]\{1,2\}\).*/\1,/' <<EOF
1
17
999
22c
53

oops
EOF
1,
17,
99,
22,
53,

oops

在每行的开头捕获一个或两个十进制数字,并在成功捕获的那些行上,用捕获的数字后跟逗号替换整行。

当然,这并不完全是您所要求的。如果您确实只想通过删除最后一个字符来准确地修改那些只包含三位数或以非数字结尾的行,那么您将看到更像这样的内容:

sed '/^\([0-9]\{3\}\|.*[^0-9]\)$/ s/.$//'

第一个较大的部分 /^\([0-9]\{3\}\|.*[^0-9]\)$/ 是一个与您要修改的行匹配的正则表达式:只包含三位十进制数字或以非数字结尾的行。第二部分是一个 s 命令,它将该行的最后一个字符替换为空。

if I would like to use a for loop to run the code on all the text files in a directory then do I have to make a bash script?

没有。 sed 在命令行上接受多个文件名。它将对所有如此命名的文件进行操作。或者,如果由于某种原因您需要将文件提供给 sed 的标准输入,那么您可以 cat 将它们全部放在一起并将结果重定向到 sed

或者更一般地说,您可以在 bash 脚本中编写的任何内容,您也可以直接在 bash 提示符下输入,例如

$ for f in *.txt; do sed 's/$/,/' $f; done

我有时会做这类事情,但编辑脚本比重新输入命令行或调用并编辑先前的命令更容易,并且将其放入脚本中可以保留它以供下次您想做同样的事情时使用。

关于linux - 使用 "sed"命令时遇到问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57327082/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com