您的位置:首页 > 其它

day 17 特殊符号与正则表达式

2018-07-31 20:21 531 查看

复习:

磁盘空间不足系列:

原因 排查过程 解决
1.block du –h; du –sh /data/* 确认之后删除
2.block(硬链接数为0,进程调用数不为0) lsof|grep delete 重启对应的服务
3.inode df -i;找出系统中大于1M的目录 删除大量小文件

时间:
mtime modify time 修改时间
ctime change time 文件属性变化时间
atime access time 访问时间(cat)

第1章 正则表达式

1.1 引号系列

1. 单引号所见即所得,单引号里面的内容会原封不动的输出2. 双引号与单引号类似,里面的特殊符号会被解析3. 反引号优先执行命令4. 不加引号与双引号类似,可以使用{}

1.2 特殊符号

1.2.1 重定向系列

>标准输出重定向(先把文件内容清空追加)>>标准输出 追加重定向2>标准错误输出重定向2>>错误追加重定向(错误信息被追加到文件内容)< 标准输入重定向 (xargs tr)<< 标准输入追加重定向(与cat配合追加多行内容) Cat >>oldboy.txt <<EOFOldboyedu.comEOF2>&1 把错误的内容和正确的内容纪录到文件中echo oldboy >/tmp/log 2>&1


1.2.2 位置系列

~ 当前用户的家目录. 当前目录.. 上一级目录cd – 返回你上次的所在位置su -

扩展:
在启动服务器ntpd服务时遇到一个问题



使用 su root 切换到root用户后,不可以使用service命令;
使用 su - 后,就可以使用service命令了。
原因:



su命令和su -命令区别就是:
su只是切换了root身份,但Shell环境仍然是普通用户的Shell;而su -连用户和Shell环境一起切换成root身份了。只有切换了Shell环境才不会出现PATH环境变量错误,报command not found的错误。
su切换成root用户以后,pwd一下,发现工作目录仍然是普通用户的工作目录;而用su -命令切换以后,工作目录变成root的工作目录了。
用echo $PATH命令看一下su和su - 后的环境变量已经变了。



以此类推,要从当前用户切换到其它用户也一样,应该使用su -命令。

1.2.3 判断系列

&& 并且
(前一个命令执行成功之后再执行后面的命令)
Ifdown eth0 && ifup eth0
|| (前一个命令执行失败之后再执行后面的命令)
ifdown eth0 #关闭eth0
ifup eth0 #启动eth0



1.2.4 无分类系列

# 注释 解释说明
root用户的命令提示符

$:
$ echo $LANG $PATH $PS1
awk取出某一列$1 $2 (取出第一列 第二列)$0 一行$NF 最后一列普通用户的命令提示符

!:
Vi /vim强制
:q!
:wq!
Find/awk取反
!ls
找出最近一次以ls开头的命令并运行
History |grep “ls”
!!
运行上一个的命令
| 管道符号
;在同一行中分割多条命令

1.3 通配符

1.3.1 *

匹配任何字符串/文本,包括空字符串
*代表任意字符(0个或多个)
ls *.txt
find –name “*.txt”
[root@zs ~]# find -type f -name "stu*"
(找出以stu开头的文件)

[root@zs ~]# find -type f -name "*.txt" (找出以.txt 结尾的文件
./2.txt
./6.txt
./4.txt
./etc/pki/nssdb/pkcs11.txt
./7.txt
./3.txt
./oldboy.txt
./1.txt
./5.txt

[root@zs ~]# find / -type f -name "stu*.txt" (找出以stu开头,并且以.txt结尾的文档

[root@zs ~]# find / -type f -name "*oldboy*" (找出文件名中包含(只要有就行)oldboy的文件)

过滤出所有含有ifconfig的文件
[root@oldboyedu50-lnb ~]# find / -type f |grep ifconfig
/usr/sbin/pifconfig
/usr/share/man/de/man8/ifconfig.8.gz
/usr/share/man/pt/man8/ifconfig.8.gz
/usr/share/man/man8/pifconfig.8.gz
/usr/share/man/man8/ifconfig.8.gz
/usr/share/man/fr/man8/ifconfig.8.gz
/sbin/ifconfig

1.3.2 {} 生成序列

生成stu 01----stu05

[root@oldboyedu50-lnb ~]# echo stu{01..5}
stu01 stu02 stu03 stu04 stu05

显示单个:
(用逗号隔开)
[root@oldboyedu50-lnb ~]# echo {1,5,100}
1 5 100

从1开始到10结束,每次加2
[root@oldboyedu50-lnb ~]# echo stu{01..10..2}
stu01 stu03 stu05 stu07 stu09

1.3.3 #通过 {} 进行备份

[root@oldboyedu50-lnb ~]# cp oldboy.txt{,.bak}
[root@oldboyedu50-lnb ~]# echo oldboy.txt{,.bak} (对上一条cp进行反向推导,输入这条命令
oldboy.txt oldboy.txt.bak (会输出oldboy.txt和oldboy.txt.bak
[root@oldboyedu50-lnb ~]# echo A{,C} (对上一条再进行简化解释,输入这一条)
A AC (会输出A和AC
[root@oldboyedu50-lnb ~]# echo A{B,C} (花括号外的会和括号内的分别组合
AB AC

小结:
1.特殊符号
2.* {} 通配符 查找文件 大多数命令都可以使用
ls *.txt

第2章 正则表达式配合三剑客进行过滤

2.1 给grep egrep配置别名并永久生效

1.[root@zs ~]# vim /etc/profile (编辑/etc/profile2.输入 alias grep='grep --color'alias egrep='egrep --color'

3. :wq (保存并退出)4.永久生效[root@zs ~]#source /etc/profile5. 进行验证[root@zs ~]# grep 3306 /etc/services

2.2 基础正则表达式

2.2.1 环境准备:

I am oldboy teacher!
I teach linux.

I like badminton ball ,billiard ball and chinese chess!
my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com my qq is 49000448

not 4900000448.
my god ,i am not oldbey,but OLDBOY!

2.2.2 查看环境

[root@oldboyedu50-lnb /oldboy]# cat oldboy.txt
I am oldboy teacher!
I teach linux.

I like badminton ball ,billiard ball and chinese chess!
my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com my qq is 49000448

not 4900000448.
my god ,i am not oldbey,but OLDBOY!

2.2.3 过滤出oldboy.txt中的oldboy

[root@oldboyedu50-lnb /oldboy]# grep oldboy oldboy.txt
I am oldboy teacher!
my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com [root@oldboyedu50-lnb /oldboy]#



2.3 第1个符号 ^

2.3.1 以....开头的行 ^

实例2-1 过滤出oldboy.txt中以m开头的行[root@oldboyedu50-lnb /oldboy]# grep '^m' oldboy.txt
my blog is http://oldboy.blog.51cto.com my qq is 49000448
my god ,i am not oldbey,but OLDBOY!



2.3.2 第二个符号 $ 以…结尾

过滤出以m结尾的行
[root@zs oldboy]# grep “m$” oldboy.txt
(我们发现有m结尾的行,但是使用egrep无法过滤)
cat -A 显示文件中所有符号 每行结尾都会有个$ 可以看出$和m之间有个空格,所以,是以空格结尾。





过滤出以(空格)$结尾的行
[root@oldboyedu50-lnb /oldboy]# grep ' $' oldboy.txt
my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com



2.3.3 第三个符号 ^$ 空行 什么符号都没有

过滤空行,由于查看不明显 所以使用grep –n 显示行号



2.3.4 第4个符号 .

任意一个字符 不会匹配空行
[root@oldboyedu50-lnb /oldboy]# grep '.' oldboy.txt
#grep 命令每一次找出了什么 grep命令执行过程
[root@oldboyedu50-lnb /oldboy]# grep -o '.' oldboy.txt



2.3.5 第5个符号 \

显示文件中以.(点)结尾的行
[root@oldboyedu50-lnb /oldboy]# grep '\.$' oldboy.txt
I teach linux.
not 4900000448.





把文件中所有的回车换行替换为tab [root@oldboyedu50-lnb /oldboy]# tr '\n' '\t' <oldboy.txt
I am oldboy teacher! I teach linux. I like badminton ball ,billiard ball and chinese chess! my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com my qq is 49000448 not 4900000448. my god ,i am not oldbey,but OLDBOY!

2.3.6 正则表达式-坑1-grep '0*' 会把文件内容都显示出来

#0* 0次 没有 grep '' 会把文件内容都显示出来
# 0次以上 0 00000000000

[root@oldboyedu50-lnb /oldboy]# grep '.*' oldboy.txt
I am oldboy teacher!
I teach linux.

I like badminton ball ,billiard ball and chinese chess!
my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com my qq is 49000448

not 4900000448.
my god ,i am not oldbey,but OLDBOY!

2.3.7 正则表达式的贪婪性

替你寻找的文字符号 有多少吃多少 有多少匹配多少
正则中表示 连续出现或所有的时候

[root@oldboyedu50-lnb /oldboy]# grep '^.*o' oldboy.txt
I am oldboy teacher!
I like badminton ball ,billiard ball and chinese chess!
my blog is http://oldboy.blog.51cto.com our size is http://blog.oldboyedu.com not 4900000448.
my god ,i am not oldbey,but OLDBOY!

grep '[a-z]' oldboy.txt



grep '[A-Z]' oldboy.txt



grep '[0-9]' oldboy.txt



grep '[a-zA-Z]' oldboy.txt



grep '[a-Z]' oldboy.txt



grep -i '[a-z]' oldboy.txt
-i 不区分大小写 ignore case



总结:
1.正则表达式与通配符区别
2.基础正则表达式
3.linux三种时间
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  day 17 特殊符号