手机网站竞价单页,移动网站不备案吗,刚建设的网站如何推广,WordPress nas正则表达式
基础正则#xff08;使用四剑客命令时无需加任何参数即可使用#xff09;
^ # 匹配以某一内容开头 如#xff1a;^grep匹配所有以grep开头的行。
$ # 匹配以某一内容结尾 如#xff1a;grep$ 匹配所有以grep结尾的行。
^$ # 匹配空行。
. # 匹配…正则表达式
基础正则使用四剑客命令时无需加任何参数即可使用
^ # 匹配以某一内容开头 如^grep匹配所有以grep开头的行。
$ # 匹配以某一内容结尾 如grep$ 匹配所有以grep结尾的行。
^$ # 匹配空行。
. # 匹配任意单个字符 如gr.p匹配gr后接一个任意字符然后是p。
* # 前一个字符出现0次及0次以上 如a*匹配所有有a的行。
.* # 表示文件中所有内容。
[] # 匹配一个指定范围内的字符如[Gg]rep匹配Grep和grep。
[^] # 匹配一个不在指定范围内的字符如[^A-Z]rep 匹配不包含 A-Z 中的字母开头的行注意在[]中除位置在第一个字符的^外其余任何带含义的特殊符号都会被还原。扩展正则 使用方法 grep命令grep -E …… 或egrep ……
sed命令sed -r ……
awk命令awk -E ……表达式 #匹配前一个字符连续出现1次或1次以上 如a 匹配字符a连续出现1次或多次的行。注通常与[]配合使用过滤连续的内容。
{n,m} #匹配前一个字符至少n次最多m次,优先匹配后面的数字例[0-9]{18} 匹配连续的18个数字
| #或者例^$|^# 匹配文件的空行或以井号开头的
() #表示一个整体反向引用/后向引用单词边界符
\b # 单词锁定符如: \bgrep\b只匹配grep;\b[0-9]{18}\b只匹配连续的18位数字
\ # 锚定单词的开始如:\grep匹配包含以grep开头的单词的行。
\ # 锚定单词的结束如grep\匹配包含以grep结尾的单词的行。
\……\ # 相当于\b...\b
\w # 匹配文字和数字字符也就是[A-Za-z0-9];
\W # \w的反置形式匹配一个或多个非单词字符,相当于[^A-Za-z0-9]四剑客
find 在指定目录下查找文件
语法形式
find [参数] [选项] #单条件查找
find [参数] [选项] [or/and] [选项] #多条件查找or/and
#使用find命令可以多条件查找
-a #需要同时满足两个、多个条件时and可以省略
-o #只需满足其中之一条件时选项
-type f/d/l/b/c #按照文件类型查找
-name NAME #按照文件名字查找
-iname NAME #按照文件名字查找忽略大小写
-inum INUM #按照文件iNode号查找
-maxdepth n #按照深度等级查找向下遍历
-size n/-n/n #按照文件大小查找
-mtime n/-n/n #按照文件修改时间查找当n0代表24小时内被修改过的文件示例
#查找/目录下文件名为dezyan.txt的文件(不区分大小写)
[rootDezyan ~]# find / -iname dezyan.txt
/proc/kcore
#查找/目录下文件大小大于1M的目录
[rootDezyan ~]# find / -size 1M -type d
注意当一个目录大小大于1M说明该目录中存在非常多的小文件
#查找/目录下的字符设备或块设备文件
[rootDezyan ~]# find / -type c -o -type b
或 find / -type c,b
#以深度等级为1查找/目录下以.log结尾的文件
[rootDezyan ~]# find / -maxdepth 1 -name *.log -type f
#查找24小时内被修改过的文件
[rootDezyan ~]# find ./ -mtime 0xargs 给其他命令传递参数的一个过滤器
注意在xargs后别名失效
语法形式
find ………… | xargs [文件操作命令]
#可以理解为将|前执行的结果甩到末尾再执行|后的命令相关使用方法
-n1 #按照第一列方式输出内容
ls -l/cat #查看找到的文件
rm [选项] #将查找的文件删除
-i cp/mv {} [参数] #将查找到的文件复制/移动到[参数位置]
cp/mv -t [参数] #将查找到的文件复制/移动到[参数位置]示例
#将/etc/下大于9M的文件复制到~目录下
[rootDezyan ~]# find /etc/ -size 9M | xargs cp -t ~
[rootDezyan ~]# ls ~ | grep hwd
hwdb.bin
#查找出所有大写的.TXT结尾的文件 然后打包成test.tar.gz
[rootDezyan ~]# find ./ -name *.TXT|xargs tar zcvf a.tar.gzexec 调用并执行指定的命令
注意使用exec将多个文件压缩成一个压缩包是不可取的因为按照exec的逻辑是将前一命令的每一次执行结果依次放入{}进行压缩时会不断覆盖文件
语法形式
find ………… -exec [命令] {} [参数] \;注意其中为shell中命令的分隔符可将多个命令同时执行mkdir test;touch 1.txt。
相关使用方法
rm [选项] {} \; #将查找的文件删除
cp/mv {} [参数] \; #将查找到的文件复制/移动到[参数位置]示例
#将/etc/下大于9M的文件复制到~目录下
[rootDezyan ~]# find /etc/ -size 9M -exec cp {} ~ \;使用和$()
语法形式
[命令选项] find ……………
[命令选项] find …………… [参数]$()效果与相同
注意如果一段命令被添加上了那么在整体命令中需要先执行中的命令类似于运算法则中的加减乘除先算。
相关使用方法
cp/mv find …… [参数]
ls/rm……示例
#将/etc/下大于9M的文件复制到~目录下
[rootDezyan ~]# cp -a find /etc/ -size 9M ~grep 强大的文本搜索工具
语法形式
grep [选项] [word] [参数]选项
-v #反转查找;
-r #当指定要查找的是目录而非文件时必须使用这项参数;
-E #识别扩展正则进行过滤;等同于egrep
-o #展示匹配过程;
------------------------------------------------------------
--color #对筛选出的WORD加颜色显示建议设置永久别名
-i #搜索时不区分大小写
-n #搜索出的结果显示行号
-w #过滤的内容两边必须是空格(类似于边界符)
-c #统计单词出现的次数;
-A #过滤到内容往下2行;
-B #过滤到内容往上2行;
-C #过滤到内容上下各2行;示例
#在/etc/passwd文件中过滤出root的行
[rootDezyan ~]# grep root /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
#不区分大小写过滤出 /etc/ssh/sshd_config 文件中包含port 22的行并输出行号
[rootDezyan ~]# grep -i -n port 22 /etc/ssh/sshd_config
17:#Port 22
#排除取反/etc/selinux/config文件中的#和注释
[rootDezyan ~]# grep -v ^#|^$ /etc/ssh/sshd_config
#统计word.txt文件中shutdown单词的个数
[rootDezyan ~]# grep -c shutdown word.txt
2
#显示文件word.txt中config的上下各两行
[rootDezyan ~]# grep -C 2 config word.txt
test 测试
server 服务
configure 配置 config conf cfg
continue 继续
next 下一个sed 功能强大的流式文本编辑器
语法形式
sed [选项] [模式][动作] [参数]选项
-n #取消内存空间默认输出不添加时sed命令会默认输出文件所有内容及匹配到的内容
-r #使模式中的正则表达式支持扩展正则
-i #对源文件进行修改不添加时不会修改模式
number #按行查找查找第n行
number或正则符号number或正则符号 #查找n到m行
/字符串或正则表达式/ #模糊查询查询包含此字符串的行
/字符串/,/字符串/ #匹配区间查询两个字符串之间的内容也可用正则
n[动作];m[动作] #指定第n行和第m行进行操作动作
p #输出打印过滤出的内容
d #删除过滤出的内容
a 字符串 #add 在……后追加xxx
i 字符串 #insert 在……前插入xxx
c 字符串 #replace 将……替换为xxx
w 文件 #将过滤到的内容写入到文件中
--------------------------------------------------
s###g #1.其中g代表全局替换#2.s///g、sg等与s###g效果相同 注意 动作中有p模式中必有n 在使用匹配区间 /开头字符串/,/结尾字符串/ 时尽量使用文件内容中唯一的、不重复的字符串 若只有一个开头有两个甚至多个结尾时输出的内容只会是开头到第一个结尾字符串之间的内容若只有开头结尾字符串没有输出的内容为开头字符串到文件末尾 sed的后向引用
sed s#(正则)(数字)(字符串)#\1\3#g #\n获取第n个()中的内容 实例
#获取IP地址
[rootDezyan ~]# ip add show ens33 | sed -rn 3s#.*et (.*)/24 .*$#\1#gp
10.0.0.101#批量创建用户test01..test03
[rootDezyan ~]# echo test{01..03} | xargs -n1 | sed -r s#(.*)#useradd \1#g | bash##批量创建用户test01..test03并设置密码为dingzhiyan1016
echo test{01..03} | xargs -n1 | sed -r s#(.*)#useradd \1 ; echo dingzhiyan1016 | passwd --stdin \1#g | bash
或
[rootDezyan ~]# echo test11{01..03} | xargs -n1 | sed -r s#(.*)#useradd \1 ; echo \1:dingzhiyan1016 | chpasswd #g | bash#批量删除用户
[rootDezyan ~]# echo user{1..20} | xargs -n1 | sed -r s#(.*)#userdel -r \1#g | bash示例
1.a.txt文件
[rootDezyan ~]# cat -n a.txt 1 The first snow came. 2 How beautiful it was, falling so silently all day long,3 all night long.4 on the mountains, on the meadows, 5 on the roofs of the living, on the graves of the dead! A2.查看a.txt文件第三行的内容
[rootDezyan ~]# sed -n 3p a.txt
all night long.3.查看a.txt文件中第三行到结尾的内容
[rootDezyan ~]# sed -n 3,$p a.txt
all night long.
on the mountains, on the meadows,
on the roofs of the living, on the graves of the dead! A4.查看a.txt中以o开头或以T开头的行
[rootDezyan ~]# sed -rn /^o|^T/p a.txt
The first snow came.
on the mountains, on the meadows,
on the roofs of the living, on the graves of the dead! A5.查看a.txt文件中包含so与meadows行之间的内容
[rootDezyan ~]# sed -n /so/,/meadows/p a.txt
How beautiful it was, falling so silently all day long,
all night long.
on the mountains, on the meadows,6.在a.txt文件1到3行后都添加一行Dezyan
[rootDezyan ~]# sed 1,3i Dezyan a.txt
Dezyan
The first snow came.
Dezyan
How beautiful it was, falling so silently all day long,
Dezyan
all night long.
on the mountains, on the meadows,
on the roofs of the living, on the graves of the dead! A7.将a.txt文件中所有的第一个on替换为under
[rootDezyan ~]# sed s#on#under#g a.txt 只替换第一个只需将g去掉即可
The first snow came.
How beautiful it was, falling so silently all day lunderg,
all night lunderg.
under the mountains, under the meadows,
under the roofs of the living, under the graves of the dead! A8.查找roofs所在行并将其替换为floor并且只显示替换行
[rootDezyan ~]# sed -n /roofs/s#roofs#floor#gp a.txt
on the floor of the living, on the graves of the dead! A9.删除文件amount.txt中的所有字母
[rootDezyan testdir]# sed -r s#[a-Z]##g amount.txtawk 文本和数据进行处理的编程语言
语法形式
awk [选项] 哪一行{print 哪一列} [file]
#逻辑按行取列先将符合条件的行尽数找出再对其中的某一列进行选取
#awk本质上其实是一种编程语言其中可以进行运算选项
-F #指定分隔符取行
#当语法形式中的{print 哪一列}为空即为取行
1.指定某行或某几行
语法形式awk NR[运算符]n file
使用awk内置变量NR -- 存储每行的行号
运算符 等于 大于 大于等于 小于 小于等于! 不等于 且|| 或
#可使用内置函数取出文件内容的最后一行awk END{print} file
2.模糊过滤取行
语法形式awk 模式 file
模式可以使用正则符号// #模糊查找文件中的字符串//,// #模糊查找两字符串之间的内容字符比对查取行
语法形式awk [选项] [取列内置变量] [模式匹配符] [表达式] file
模式匹配符 #某列等于……! #某列不等于……~ #使用正则匹配字符串!~ #使用正则匹配字符串并取反
表达式任意字符正则表达式数字比对查取行
语法形式awk [选项] [取列内置变量] [模式匹配符][运算符]n file取列
#当语法形式中的哪一行为空即为取列
语法形式awk {print [内置变量]} file
awk内置变量$0 # 表示整行$n # 表示文件的第n列 , # 逗号表示空格NF # 表示每一行最后一列的列号$NF # 表示最后一列;$(NF-1)表示倒数倒数第二列 -- 也体现了awk支持运算的特性指定分隔符取列
语法形式awk -F [表达式] {print [内置变量]} file
表达式任意字符正则表达式指定分隔符按行取列
awk -F [表达式] 取行方式取列方式 fileBEGIN的用法
#BEGIN 是一个特殊的模式它在处理任何输入行之前执行一次。
awk -F [表达式] BEGIN{print 任意内容} file示例
#过滤文件的选择/etc/passwd文件的前10行存储到了~/passwd.txt中
#即head /etc/passwd ~/passwd.txt
#在未明确说明分隔符时默认指定分隔符为:
1.指定取行
#取出文件最后一行
[rootDezyan ~]# awk END{print} passwd.txt
#取出第7行和第9行以及两行之间的内容
[rootDezyan ~]# awk NR7NR9 passwd.txt2.模糊取行
#取出文件中以root开头和以adm开头以及两行之间的内容
[rootDezyan ~]# awk /^root/,/^adm/ passwd.txt3.字符比对取行
#取出文件中用户名为root的行
[rootDezyan ~]# awk -F: $1root passwd.txt
#取出文件中以nologin结尾的行
[rootDezyan ~]# awk -F: $NF~nologin$ passwd.txt4.数字比对取行
#取出用户uid大于6的行
[rootDezyan ~]# awk -F: $36 passwd.txt5.取列
#输出文件每一行最后一列的序号以:或\或:\为分隔符
[rootDezyan ~]# awk -F [:/] {print NF} passwd.txt
#输出文件的第一列和最后一列以:或\或:\为分隔符
[rootDezyan ~]# awk -F [:/] {print $1,$NF} passwd.txt6.BEGIN用法示例
#在输出文件第一列内容前先输出“用户名”
[rootDezyan ~]# awk -F: BEGIN{print 用户名}{print $1} passwd.txt
#让输出的第一列内容前都有“用户名”几个字
[rootDezyan ~]# awk -F: {print 用户名 $1} passwd.txt7.综合运用
#输出文件最后一行的最后一列
[rootDezyan ~]# awk -F: END{print $NF} passwd.txt
#输出大于第5行到结尾的内容并取出第3列
[rootDezyan ~]# awk -F: NR5{print $3} passwd.txt
#输出用户uid大于6的行并输出用户名
[rootDezyan ~]# awk -F: $36{print $1} passwd.txt
#将系统重不能登录的用户输出到nologin.txt文件中并在文件的开头显示“不能登录的用户有”##注使用awk命令不能使用管道符
[rootDezyan ~/testdir]# awk -F: BEGIN{print 不能登录的用户有} $NF~nologin${print $1} /etc/passwd nologin.txt
不能登录的用户有
bin
daemon
……………………