文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。
当前回答
您可以使用以下awk解决方案-
awk '/^#/ {sub(/#.*/,"");getline;}1' inputfile
其他回答
您还可能希望删除空行
sed -E '/(^$|^#)/d' inputfile
这可以用sed一行代码完成:
sed '/^#/d'
这表示,“找到所有以#开头的行,并删除它们,留下其他所有行。”
这个回答建立在基思先前回答的基础上。
Egrep -v "^[[:blank:]]*#"应该过滤掉注释行。
Egrep -v "^[[:blank:]]*(#|$)"应该过滤掉注释和空行,这通常很有用。
有关[:blank:]和其他字符类的信息,请参见https://en.wikipedia.org/wiki/Regular_expression#Character_classes。
如果你想从文件中删除一个特定的单词,那么这样做:
grep -v '^pattern' currentFileName > newFileName && mv newFileName currentFileName
因此,我们删除了以模式开头的所有行,将内容写入新文件,然后将内容复制回源/当前文件。
您可以使用以下awk解决方案-
awk '/^#/ {sub(/#.*/,"");getline;}1' inputfile