学习shell的思想
思想(KISS)相当重要。KISS(keep it simple stupid)。
这是其实不难,只要按照一下思路进行就ok。
- 把复杂的问题简单化,模块化;
- 写出每一个模块的伪代码;
- 组装你的模块;
- 写出Shell Code;
- 测试(Test);
知道什么时候用什么实现,远比你知道怎么写code更重要。(shell不是万能的,择优取之。)shell最精华、最美的地方在于他有现成的命令可以使用,不用考虑底层的问题。作为上层工作最好的工具,所谓上层指的是系统管理、网络管理等等。
讨厌的正则
我们平常只所以讨厌一个事物,本质是因为自己驾驭不了它。比如你讨厌一个人,是因为你一开始就以易于对待他人的方法和心态去和他沟通和接触。
如何驾驭正则
1、乱七八糟的符号
举例:grep是行模式,默认以行显示
如上显示三行
如上显示两行
如上显示一行
总结什么是正则,两个单引号中间的部分就是正则。
正则有什么用
查找匹配
正则提供了一些特殊符号,通过这些符号去替换一些东西。
1、一个字符(如何在整篇文章中查找一个字符)
举例:在整篇文章中查找字母a
使用vi编辑器打开/etc/passwd, 在末行模式下查找a
输入 :/a/
还有你想要查找abc,是查找一个是或的关系,也就是说要找a,ab,ac,b,bc,c,abc这样的情况,那么就用[]来表示。
输入 :/[abc]/
or :/[a-c]/
or :/a|b|c/
中括号,就是把你想要定位的东西写入到里面。
任意一个字符
[]
选择中括号里面的任意一个
[^]
取反,取非
[:alnum:]
阿尔法字符加数字
[:alpha:]
任意一个字符 [[:alpha]]
[:digit:]
任意一个数字 [[:digit:]]
(对它取反的话[^[:digit:]]
)意为除了任意一个数字。
[:lower:]
小写
[:upper:]
大写
[:space:]
空格
[:punct:]
标点
以上用什么定位一个字符,请看下面
如下图 -E 代表的是一个扩展表达式。其中dp之间的
|
代表的是或的关系,任意取一。转义字符:\
Example: 当 .
在这不转义的时候代表的是正则中的 .
代表匹配任意一个字符.
当
\.
转义之后代表着文本中真正真实存在我们看到的具体的 .
2、字符的边界, 查找匹配多个字符需要用到字符边界
^
开头(一行开头)
$
结尾(一行结尾)
\<
左边界
\>
右边界
cat -A /etc/passwd
显示其字符边界。
Linux下 dos2unix 命令可以吧windows格式文件转换为Linux, unix2dos 命令可以把Linux格式转为Windows
3、重复
*
重复0次或多次, 注意命令 ls *
中的 *
不是正则,是shell中的通配符;正则中 *
代表前面出现0次或者多次。 * > = 0
Example: 匹配所有字符,字符每个出现次数大于等于0次
a的次数大于等于0次,字符中没有a,它相当于没有,所以匹配所有,但是不会高亮颜色,因为没有a.
上图可以看出第2、5行没有d,那如果要只匹配d的行打印出来咋整:
+
匹配一个或者多个 + >= 1
Example:匹配d,
d+
代表每一行匹配d
的次数大于等于1?
匹配0个或者1个 <= 1
Example:
精确匹配次数
{}
中填入数字代表匹配次数,大于等于次数的行被匹配出来
Example: a精确匹配5次,a出现的次数大于等于5次的行被匹配出来.
精确到范围
{n,m}
Example: {3,5} 匹配3至5,包括3和5.
4、组
组的重复
Example:pig 一组,dog一组。 其中 |
有或的意思,如果有组 pig或者dog,就匹配出这一样.
pig一组,dog一组。 pig或者dog出现的次数大于等于1,就匹配这一样。
pig一组,dog一组。pig或者dog出现满足某一行精确到出现两次就匹配。
本文通过
Linux天使团
的讨厌的Shell正则整理。