文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。
当前回答
与雷蒙德解决方案相反的是:
sed -n '/^#/!p'
"不打印任何东西,除了不以#开头的行"
其他回答
这里有一个循环的所有文件与一些扩展名:
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
您还可能希望删除空行
sed -E '/(^$|^#)/d' inputfile
与雷蒙德解决方案相反的是:
sed -n '/^#/!p'
"不打印任何东西,除了不以#开头的行"
您可以直接编辑您的文件
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一行代码完成:
sed '/^#/d'
这表示,“找到所有以#开头的行,并删除它们,留下其他所有行。”