文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。
我有点惊讶,居然没有人提出最明显的解决方案:
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。
您可以直接编辑您的文件
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
这里有一个循环的所有文件与一些扩展名:
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 '/^$|^\s*#/d' inputfile
例如,查看下面删除的3行(包括行号!):
1. # first comment
2.
3. # second comment
在测试上面的命令之后,您可以使用option -i来编辑输入文件。
就这!
如果你想从文件中删除一个特定的单词,那么这样做:
grep -v '^pattern' currentFileName > newFileName && mv newFileName currentFileName
因此,我们删除了以模式开头的所有行,将内容写入新文件,然后将内容复制回源/当前文件。
推荐文章
- 检查bash变量是否等于0
- 只使用md5sum获取哈希值(没有文件名)
- 如何生成一个核心转储在Linux上的分段错误?
- 在Bash中测试非零长度字符串:[-n "$var"]或["$var"]
- 如何删除超过X小时的文件
- 如何创建Bash别名?
- 将所有变量从一个shell脚本传递到另一个?
- 如何删除shell脚本中文件名的扩展名?
- 使用xargs调用shell函数
- 如何限制从grep返回的结果的数量?
- 'find -exec'是Linux中的shell函数
- 将值从管道读入shell变量
- 在Bash中重用上一个命令的输出
- RE错误:在Mac OS X上的非法字节序列
- 对bash脚本函数中定义的变量使用curl POST