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


当前回答

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

sed -n '/^#/!p'

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

其他回答

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

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

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

sed '/^#/d'

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

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

sed -n '/^#/!p'

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

您还可能希望删除空行

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

这里有一个循环的所有文件与一些扩展名:

ll -ltr *.filename_extension > list.lst

for i in $(cat list.lst | awk '{ print $8 }') # validate if it is the 8 column on ls 
do
    echo $i
    sed -i '/^#/d' $i
done