文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。
当前回答
这个回答建立在基思先前回答的基础上。
Egrep -v "^[[:blank:]]*#"应该过滤掉注释行。
Egrep -v "^[[:blank:]]*(#|$)"应该过滤掉注释和空行,这通常很有用。
有关[:blank:]和其他字符类的信息,请参见https://en.wikipedia.org/wiki/Regular_expression#Character_classes。
其他回答
这可以用sed一行代码完成:
sed '/^#/d'
这表示,“找到所有以#开头的行,并删除它们,留下其他所有行。”
您可以使用以下awk解决方案-
awk '/^#/ {sub(/#.*/,"");getline;}1' inputfile
与雷蒙德解决方案相反的是:
sed -n '/^#/!p'
"不打印任何东西,除了不以#开头的行"
我有点惊讶,居然没有人提出最明显的解决方案:
grep -v '^#' filename
这就解决了前面提到的问题。
但请注意,一个常见的约定是,从#到行尾的所有内容都被视为注释:
sed 's/#.*$//' filename
例如,它将字符串字面量中的#字符作为注释的开始(这可能与您的情况相关,也可能不相关)(并且它会留下空行)。
以任意空格开头,后跟#的行也可能被视为注释:
grep -v '^ *#' filename
如果空格只是空格,或者
grep -v '^[ ]#' filename
其中两个空格实际上是一个空格后面跟着一个字面制表符(键入“control-v制表符”)。
对于所有这些命令,省略filename参数以从标准输入中读取(例如,作为管道的一部分)。
这个回答建立在基思先前回答的基础上。
Egrep -v "^[[:blank:]]*#"应该过滤掉注释行。
Egrep -v "^[[:blank:]]*(#|$)"应该过滤掉注释和空行,这通常很有用。
有关[:blank:]和其他字符类的信息,请参见https://en.wikipedia.org/wiki/Regular_expression#Character_classes。