出于安全性的考虑,不建议在bash脚本中注释掉不使用的代码。也就是说如果某段代码不使用了,那么应该删除掉,而不是简单地注释掉。假如你突然意识到这一点,而以前并没有遵从这个原则,现在需要找出脚本中的注释性代码,这可能是一个不小的工作量,让我们写一个脚本来帮助你吧,准确性无法达到百分之百,但是能够提升效率。
1.找出注释性代码的特点。
因为是bash脚本,注释行必然包含#
grep “#”
2.判断其是普通注释还是代码注释
这是重点,也是难点,如何判断一个注释行是普通注释还是对代码的注释呢?
# this is a common comment
下面这行是对代码的注释
# if [ -e /etc/passwd ];then cat /etc/passwd;fi
3.要分析bash代码的特点,在这些特点之前加上一个#,这个就是注释代码。
所以要把注释代码的模式写入一个pattern文件,使用grep查找就可以了。
grep -E -f pattern.txt
pattern.txt内容如下:
#[\ ]if
#[\ ]for
#[\ ]*while
grep -e选项,用来指定多个模式,查找符合pattern1或pattern或pattern3的模式。
grep -e pattern1 -e pattern2 -e pattern3 -r -n filepath or dirpath
grep读取文件中的模式。
grep -f pattern_file
-r 递归选项 –recursive
-n 显示行号
-E 支持正则表达式
-l 显示匹配的文件名
-L, –files-without-match
-q 安静模式
-v 相反
-i 忽略大小写
问题:linux命令执行的返回值时数字还是字符串?
grep的返回值在自动判断的时候常常用到
特殊之处在于使用-v的时候
grep -v “pattern” filename 也就是有没有pattern的行才是返回0,这个逻辑有点绕。
0意味着有条件所指定的值
if [ $? -eq 0 ]
then
do sth
fi
if [ $? -ne 0 ]
then
do sth
fi
本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-01/139219.htm