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


当前回答

这个回答建立在基思先前回答的基础上。

Egrep -v "^[[:blank:]]*#"应该过滤掉注释行。

Egrep -v "^[[:blank:]]*(#|$)"应该过滤掉注释和空行,这通常很有用。

有关[:blank:]和其他字符类的信息,请参见https://en.wikipedia.org/wiki/Regular_expression#Character_classes。

其他回答

您还可能希望删除空行

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

这可以用sed一行代码完成:

sed '/^#/d'

这表示,“找到所有以#开头的行,并删除它们,留下其他所有行。”

删除所有空行,以及所有空格后以#开头的行:

sed -E '/^$|^\s*#/d' inputfile

例如,查看下面删除的3行(包括行号!):

1. # first comment
2.
3.         # second comment

在测试上面的命令之后,您可以使用option -i来编辑输入文件。

就这!

您可以直接编辑您的文件

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

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

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