摘要:符号^表示行的开头,$表示行的结尾(不是字符,是位置),^$表示空,因为只有行首和行尾。
sed:Stream Editor。
.*代表所有内容
/^$/ 表示空行
sed 's/pattern/& \n/g' filename
在所有行首添加
sed 's/pattern/\ n&' filename
在所有行末添加
&代表pattern。
在第一行前插入文本:
sed -i '1i \ 插入字符串' filename
在最后一行插入:
sed -i '$a \ 插入字符串' filename
grep -[acinv] '搜索内容' filename
-a:以文本文件方式搜索
-c: 计算找到符合行的次数
-i: 忽略字母大小写
-n:顺便输出行号
-v: 反向选择,找到没有搜索字符串的行。
搜索字符串可以是正则表达式。
:表示其中的某一个字符。[abc]表示a、b或c。
可以用^符号做内的前缀,表示除内的字符之外的字符。
符号^表示行的开头,$表示行的结尾(不是字符,是位置),^$表示空,因为只有行首和行尾。
在MS系统下生成的文本文件,换行时会加上一个^M字符,所以最后的字符会是隐藏的^M,在处理Windows下面的文本需要特别注意。
可以用cat dos_file | tr -d '\r'> unix_file来删除^M字符。
在bash中*代表通配符,用来表示任意个字符。但是在正则表达式中,*表示有0个或者多个某字符。
点(.)代表一个任意字符,必须存在。
符号.*只能限制0个或者多个字符,如果要确切地限制字符的重复数量,就要用{范围}这种方式。范围是数字,用逗号隔开。
中的符号^表示否定的意思。
'[^a-z\.!^-]' 表示没有小写字母,没有点(.),没有感叹号(!),没有空格,没有横杠-的字符串,第二个^表示小空格。
grep只支持基础表达式,而egrep 支持扩展。
egrep -v '^$|^#' regular_express.txt
这里的符号|表示或的关系,即满足^$或者^#的字符串。
去掉空白行和行首为#的注释行。
扩展特殊符号:
+:表示一个或者多个重复字符。
?:表示0个或者1个字符。
|:表示或的关系。
:把部分内容合并成一个单元组。
find命令的一般形式是:
find pathname -options [ -print -exec -ok…]
-exec:表示find 命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为:
'command'{} \;在{}和符号\;之间有空格。
exec选项后面跟随着所要执行的命令或者脚本,然后是一对{}、一个空格和一个\符号,最后是一个分号; 。
举例: find . -type f -exec ls -l {} \;
删除更改时间在5天之前的文件:
find . -name "*.log" -mtime +5 -ok rm {} \;
使用find命令的-exec选项处理匹配到的文件时,find命令将所有匹配到的文件一起传递给-exec执行。但是有些系统对传递给exec的命令长度是有限制的。在find命令运行几分钟之后,就会出现溢出错误。错误信息通常是“参数列太长”或者“参数列溢出”。
find命令把匹配匹配到的文件也可以传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样xargs就可以先处理最先获取的那一部分文件,然后是下一批,并且如此继续下去。
有些系统中,使用-exec命令会为处理每一个匹配到的文件而发起一个相应的进程,并非将匹配到的文件全部作为参数一次执行。这样,在有些情况下就会出现进程过多,系统性能下降的问题,因而效率不高。
使用xargs命令则只有一个进程。在使用xargs命令时,究竟是一次获取所有的参数,还是分批取得参数,包括每一次所获取参数的数目,都会根据命令的选项以及系统内核中相应的可调参数来确定。
MySQL主从中Slave服务器的IO和SQL状态必须都为YES。
北京的西山上
鼓励的话语:能管得住有本事的人,才是最大的本事!
来源:小宇科技天地