目录
1、sed -i 's/#rm -f \/a\/b/rm -f \/a\/b/g' hello/file
2、 sed -i 's/^bind-address.*/bind-address = 0.0.0.0/' $MYSQL_CONF_FILE
3、 Sed -r ‘s/root/ROOT/gi/’ /etc/passwd
一、正则表达式
. |
ls .txt |
匹配当前目录下以.txt结尾的文件 |
* |
grep 'a*' file.txt |
匹配文件中所有连续出现的字母a |
+ |
grep 'ba+' file.txt |
配文件中所有包含b后跟着一个或多个a的字符串。 |
? |
grep 'colou?r' file.txt |
匹配文件中包含color或colour的字符串。 |
[ ] |
grep '[aeiou]' file.txt |
匹配文件中包含任何一个元音字母的字符串 |
[^] |
’grep '[^0-9]' file.txt |
匹配文件中不包含数字的行 |
- |
grep '[a-z]' file.txt |
匹配文件中包含小写字母的字符串 |
\b |
grep '\bword\b' file.txt |
匹配文件中独立的单词word |
^ |
grep '^start' file.txt |
匹配文件中以start开头的行 |
$ |
grep 'end$' file.txt |
匹配文件中以end结尾的行 |
二、 grep的使用
cat test.txt |grep ^u |
找出test.txt中以u开头的行的内容 |
cat test.txt |grep ^[^u] |
找出test.txt中不以u开头的行的内容 |
cat /etc/passwd | grep -n root |
将/etc/passwd,取出出现 root 的行,(-n)显示行号 |
ps aux | wc -l |
显示进程的个数 |
grep "wl" 1.txt 2.txt 3.txt |
在 1.txt、2.txt、3.txt中查找wl |
grep -r "wl" path/inc |
在path/inc中递归搜索wl |
grep "wl" path/*.txt |
path目录下所有的txt,搜索wl |
三、sed流编辑器(一般用与替换文本)
1、sed -i 's/#rm -f \/a\/b/rm -f \/a\/b/g' hello/file
-i:直接在原始文件上进行编辑
s表示替换操作的开始
g表示全局替换(如果没有g,则若多行出现且一行有多处出现,则只会替换每一行的第一个)
#rm -f \/a\/b/待替换的模式,是#rm -f /a/b的文本
rm -f \/a\/b/是替换后的模式,是rm -f /a/b的文本
表示将hello/file中的#rm -f /a/b替换成为rm -f /a/b
2、 sed -i 's/^bind-address.*/bind-address = 0.0.0.0/' $MYSQL_CONF_FILE
^bind-address.*:匹配以"bind-address"开头的行。
bind-address = 0.0.0.0:替换匹配到的行为"bind-address = 0.0.0.0"。
3、 Sed -r ‘s/root/ROOT/gi/’ /etc/passwd
在etc/passwd目录下的所有文件(-r),在文本(i)中将所有(g)的root替换(s)成ROOT
4、 转义字符
Sed -r ‘\crootcd’ passwd
Sed -r ‘\#root#d’ passwd(\作转义字符,告诉sed要将#看作是普通字符)
将passwd中的root删掉,两个#可以换成任意的字符
四、awk的使用(用于输出列)
awk '{print $2}' file.txt |
打印file.txt中的第二列 |
awk -F':' '{print $1, $NF}' /etc/passwd |
以:为分隔符,打印第一列和最后一列 |
awk -va=1 '{print $1,$1+a}' log.txt |
-va=1,指定变量a,赋值为1,则输出第一列和第二列的内容 |