文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。
当前回答
删除所有空行,以及所有空格后以#开头的行:
sed -E '/^$|^\s*#/d' inputfile
例如,查看下面删除的3行(包括行号!):
1. # first comment
2.
3. # second comment
在测试上面的命令之后,您可以使用option -i来编辑输入文件。
就这!
其他回答
与雷蒙德解决方案相反的是:
sed -n '/^#/!p'
"不打印任何东西,除了不以#开头的行"
您可以使用以下awk解决方案-
awk '/^#/ {sub(/#.*/,"");getline;}1' 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
这个回答建立在基思先前回答的基础上。
Egrep -v "^[[:blank:]]*#"应该过滤掉注释行。
Egrep -v "^[[:blank:]]*(#|$)"应该过滤掉注释和空行,这通常很有用。
有关[:blank:]和其他字符类的信息,请参见https://en.wikipedia.org/wiki/Regular_expression#Character_classes。
删除所有空行,以及所有空格后以#开头的行:
sed -E '/^$|^\s*#/d' inputfile
例如,查看下面删除的3行(包括行号!):
1. # first comment
2.
3. # second comment
在测试上面的命令之后,您可以使用option -i来编辑输入文件。
就这!