文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。


当前回答

如果你想从文件中删除一个特定的单词,那么这样做:

grep -v '^pattern' currentFileName > newFileName && mv newFileName currentFileName

因此,我们删除了以模式开头的所有行,将内容写入新文件,然后将内容复制回源/当前文件。

其他回答

您可以直接编辑您的文件

sed -i '/^#/ d'

如果您还想删除以一些空白开始的注释行,请使用

sed -i '/^\s*#/ d'

通常,您希望保留脚本的第一行,如果它是sha-bang,那么sed不应该删除以#!开头的行。它还应该删除那些只包含散列而不包含文本的行。把它们放在一起:

sed -i '/^\s*\(#[^!].*\|#$\)/d'

为了与所有sed变量一致,你需要在-i选项中添加一个备份扩展名:

sed -i.bak '/^\s*#/ d' $file
rm -Rf $file.bak

与雷蒙德解决方案相反的是:

sed -n '/^#/!p'

"不打印任何东西,除了不以#开头的行"

您还可能希望删除空行

sed -E '/(^$|^#)/d' inputfile

我有点惊讶,居然没有人提出最明显的解决方案:

grep -v '^#' filename

这就解决了前面提到的问题。

但请注意,一个常见的约定是,从#到行尾的所有内容都被视为注释:

sed 's/#.*$//' filename

例如,它将字符串字面量中的#字符作为注释的开始(这可能与您的情况相关,也可能不相关)(并且它会留下空行)。

以任意空格开头,后跟#的行也可能被视为注释:

grep -v '^ *#' filename

如果空格只是空格,或者

grep -v '^[  ]#' filename

其中两个空格实际上是一个空格后面跟着一个字面制表符(键入“control-v制表符”)。

对于所有这些命令,省略filename参数以从标准输入中读取(例如,作为管道的一部分)。

您可以使用以下awk解决方案-

awk '/^#/ {sub(/#.*/,"");getline;}1' inputfile