Linux基础知识之sed、grep、find

摘要:符号^表示行的开头,$表示行的结尾(不是字符,是位置),^$表示空,因为只有行首和行尾。

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。

北京的西山上

鼓励的话语:能管得住有本事的人,才是最大的本事!

来源:小宇科技天地

相关推荐