文件中所有带有注释的行都以#开头。如何删除以#开头的所有行(仅是那些行)?其他包含#但不在行首的行应该被忽略。
当前回答
与雷蒙德解决方案相反的是:
sed -n '/^#/!p'
"不打印任何东西,除了不以#开头的行"
其他回答
您可以使用以下awk解决方案-
awk '/^#/ {sub(/#.*/,"");getline;}1' inputfile
这可以用sed一行代码完成:
sed '/^#/d'
这表示,“找到所有以#开头的行,并删除它们,留下其他所有行。”
与雷蒙德解决方案相反的是:
sed -n '/^#/!p'
"不打印任何东西,除了不以#开头的行"
您还可能希望删除空行
sed -E '/(^$|^#)/d' 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
推荐文章
- 检查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