第1章 特殊符号
1.1 引号系列
1.1.1 单引号
所见即所得 单引号里面的内容会原封不动的输出
[root@oldboyedu50-lnb ~]# echo 'oldboy $LANG $PS1 $(hostname) `pwd`'oldboy $LANG $PS1 $(hostname) `pwd`
1.1.2 双引号
与单引号类似 里面的特殊符号会被解析(运行)
[root@oldboyedu50-lnb ~]# echo "oldboy $LANG $PS1 $(hostname) `pwd`"oldboy en_US.UTF-8 [\u@\h \w]\$ oldboyedu50-lnb /root
1.1.3 反引号
优先执行命令
1.2 重定向符号
1.2.1 输出重定向
标准输出重定向 会先把文件内容清空 >
标准输出追加重定向 >>
标准错误输出重定向 2>
标准错误输出追加重定向 2>>
1.2.2 输入重定向
标准输入重定向 <
xagrs tr
#######################################################################################
标准输入追加重定向 <<
与cat配合追加多行内容
1.2.3 错误的和正确的都记录
把错误的内容和正确的内容记录到文件中2>&1
echo oldboy /tmp/log 2>&1
1.3 位置系列
~ 当前用户的家目录
. 当前目录
.. 上一级目录
- 返回上一次所在的位置
cd - su -
1.4 判断系列
1.4.1 &&
前一个命令 执行成功了 再执行后面的 &&
如 ifdown eth0 && ifup eth0
1.4.2 ||
前一个命令执行失败再执行后一个命令(执行成功的话后面的命令不执行) ||
[root@oldboyedu50-lnb ~]# ls /oldboy && echo 目录已存在 使用&&前一个命令正确后面内容才会显示test.sh t.sh.bak xiaodong xingfujieyingsui.gz目录已存在[root@oldboyedu50-lnb ~]# ls /ooooo && echo 目录已存在 目录不正确 后面的内容没有显示ls: cannot access /ooooo: No such file or directory[root@oldboyedu50-lnb ~]#[root@oldboyedu50-lnb ~]# ls /ooooo || echo 目录不存在 || 前一个命令不正确 后一个命令才会执行ls: cannot access /ooooo: No such file or directory目录不存在
1.5 其他符号
1.5.1 #号
# 注释
root用户的命令提示符
[root@oldboyedu-50 ~]#
1.5.2 $符
echo $LANG $PS1 $PATH 变量
awk 取出某一列
$1第一列 $2 第二列 $0 一整行 $NF 最后一列
普通用户的命令提示符 $
1.5.3 ! 叹号
vi/vim中表强制
:q! :wq!
find / awk 表示取反
!ls
找出最近一次以ls开头的命令并运行
!!
运行上一个的命令
1.5.4 | 管道符号
1.5.5 ; 分隔符
在同一行中分割多条命令
第2章 通配符 找文件名
2.1 *(星号)
所有
以什么什么结尾
以.conf结尾的文件
find / -type f -name "*.conf"
包含什么什么的文件
找出系统中文件名包含ifconfig (文件名中有ifconfig就行)[root@oldboyedu-50 /data]# find / -type f -name "*ifconfig*"[root@oldboyedu-50 /data]# find / -type f |grep ifconfig
2.2 {}
2.2.1 生成序列
[root@oldboyedu50-lnb ~]# echo stu{01..5} 生成简单的序列stu01 stu02 stu03 stu04 stu05[root@oldboyedu50-lnb ~]# echo {1,5,100} 中间以,分开 只显示里面的内容1 5 100#{} 生成序列#生成 stu001 ..... stu005[root@oldboyedu50-lnb ~]# echo stu{01..10} 前面有0在第一个数字加上即可stu01 stu02 stu03 stu04 stu05 stu06 stu07 stu08 stu09 stu10[root@oldboyedu50-lnb ~]# echo stu{01..10..2} 以1 3 5 7顺序显示stu01 stu03 stu05 stu07 stu09[root@oldboyedu-50 /data]# echo stu{001..5} 练习stu001 stu002 stu003 stu004 stu005[root@oldboyedu-50 /data]# echo stu{01..05..2} 练习stu01 stu03 stu05
2.2.2 备份
{}备份的快捷用法 通过{}备份
[root@oldboyedu-50 /data]# echo a{b,c} 以,隔开 显示方式变为ab acab ac[root@oldboyedu-50 /data]# echo a{,c} 括号里没有b 会变成a aca ac[root@oldboyedu-50 /data]# lltotal 0-rw-r--r--. 1 root root 0 Jul 10 22:53 linux.txt-rw-r--r--. 1 root root 0 Jul 10 22:17 oldboy[root@oldboyedu-50 /data]# cp linux.txt{,.bak} 快捷备份的方式[root@oldboyedu-50 /data]# lltotal 0-rw-r--r--. 1 root root 0 Jul 10 22:53 linux.txt-rw-r--r--. 1 root root 0 Jul 10 22:53 linux.txt.bak-rw-r--r--. 1 root root 0 Jul 10 22:17 oldboy
第3章 基础正则表达式
3.1 了解正则
3.1.1 为什么使用正则
帮助我们快速过滤
特殊符号表示文字 文本
提高效率 省事
3.1.2 正则表达式与通配符的区别
通配符是用来找文件名的。Linux大部分命令都支持
正则表达式用来在文件中找内容、文本。三剑客支持
3.1.3 使用正则表达式注意事项
正则表达式按照行为单位处理文件(grep/sed)
使用必须在英文环境
给 grep egrep设置别名 --color
3.1.4 正则表达式的贪婪性
替你寻找的文字符号 有多少吃多少 有多少匹配多少
正则中表示 连续出现或所有的时候
3.2 基础正则符号
准备环境
用vim写入[root@oldboyedu-50 oldboy]# cat oldboy.txtI am oldboy teacher!I teach linux. I like badminton ball ,billiard ball and chinese chess!my blog is http://oldboy.blog.51cto.comour size is http://blog.oldboyedu.commy qq is 49000448 not 4900000448.my god ,i am not oldbey,but OLDBOY!
3.2.1 ^ 以….开头
^ 以xxxx开头的行
比如 ^m 以m开头的一行
[root@oldboyedu-50 oldboy]# grep '^m' oldboy.txtmy blog is http://oldboy.blog.51cto.commy qq is 49000448my god ,i am not oldbey,but OLDBOY!
3.2.2 $ 以….结尾
$ 以….结尾
比如m$ 以m结尾的一行
cat -A 显示文件中所有符号(每行结尾都会有个$)
[root@oldboyedu50-lnb /oldboy]# grep ' $' oldboy.txt 显示以空格结尾的行my blog is http://oldboy.blog.51cto.comour size is http://blog.oldboyedu.com
3.2.3 ^$ 空行
什么符号都没有
-n 显示行号
[root@oldboyedu-50 oldboy]# grep '^$' oldboy.txt [root@oldboyedu-50 oldboy]# grep -n '^$' oldboy.txt3:8:
3.2.4 . 任意一个字符
不会匹配空行
grep -o 显示grep命令执行过程
[root@oldboyedu50-lnb /oldboy]# #grep '.' oldboy.txt#grep 命令每一次找出了什么 显示grep命令执行过程[root@oldboyedu50-lnb /oldboy]# grep -o '.' oldboy.txt
3.2.5 \ 转义字符
转义字符
显示文件中以.(点)结尾的行
[root@oldboyedu50-lnb /oldboy]# grep '\.$' oldboy.txt 使用\取消.的特殊含义I teach linux.not 4900000448.[root@oldboyedu50-lnb /oldboy]# tr '\n' '\t'
3.2.6 * 前一个字符连续出现了0次或0次以上
0* 0次 没有 grep ''会把文件内容都显示出来
0次以上 0 00000000000
[root@znix ~]# grep "0*" clsn.txt 坑1-grep '0*' 会把文件内容都显示出来I am clsn teacher!I teach linux. I like badminton ball ,billiard ball and chinese chess!my blog is http://clsn.blog.51cto.com our site is http://www.etiantian.org my qq num is 49000448. not 4900000448.my god ,i am not oldbey,but clsn![root@znix ~]# grep -o "0*" clsn.txt00000000
3.2.7 . * 所有 任何字符 包含空行
. * 所有 任何字符 包含空行
正则表达式的贪婪性
替你寻找的文字符号,有多少匹配多少
正则中表示 连续出现或所有的时候
[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.comour size is http://blog.oldboyedu.commy qq is 49000448 not 4900000448.my god ,i am not oldbey,but OLDBOY!
###################################################################################################
[root@oldboyedu50-lnb /oldboy]# grep '^.*o' oldboy.txtI am oldboy teacher!I like badminton ball ,billiard ball and chinese chess!my blog is http://oldboy.blog.51cto.comour size is http://blog.oldboyedu.comnot 4900000448.my god ,i am not oldbey,but OLDBOY!
3.2.8 [] [abc] a或b或c
grep -i 不区分大小写
grep '[a-z]' oldboy.txt 搜索a-z的内容grep '[A-Z]' oldboy.txt 搜索A-Z的内容grep '[0-9]' oldboy.txt 搜索0-9的内容 grep '[a-zA-Z]' oldboy.txt 搜索a-z或A-Z的内容grep '[a-Z]' oldboy.txt 搜索a-z或A-Z的内容grep '[a-zA-Z]' oldboy.txt === grep '[a-Z]' oldboy.txt(该项只适用于grep)grep -i 不区分大小写 ignore case
3.2.9 [^abc] 排除a或排除b或排除c
3.2.9.1 [^abc]
[^abc] 表示找排除a或排除b或排除c之外的其他字符
[root@znix ~]# grep "[^abc]" clsn.txtI am clsn teacher!I teach linux.I like badminton ball ,billiard ball and chinese chess!my blog is http://clsn.blog.51cto.comour site is http://www.etiantian.orgmy qq num is 49000448.not 4900000448.my god ,i am not oldbey,but clsn!
3.2.9.2 grep -v 排除与[^abc]
grep -v 排除行
[^abc] 字符或文字