1.整理正则表达式博客
re http://www.cnblogs.com/oyoui/p/6599846.html
2.grep(正则表达式及字符处理)
1.显示出所有含有root的行:
[root@web2 mnt]# grep 'root' passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
2.输出任何包含bash的所有行,还要输出紧接着这行的上下各两行的内容:
[root@web2 mnt]# grep -A 2 -B 2 'root' passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
--
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
[root@web2 mnt]# grep -A 2 -B 2 'bash' passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
--
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
chrony:x:997:995::/var/lib/chrony:/sbin/nologin
jack:x:1000:1000:jack:/home/jack:/bin/bash
3. 显示出有多少行含有nologin。
[root@web2 mnt]# grep -n 'nologin' passwd
2:bin:x:1:1:bin:/bin:/sbin/nologin
3:daemon:x:2:2:daemon:/sbin:/sbin/nologin
4:adm:x:3:4:adm:/var/adm:/sbin/nologin
5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
10:operator:x:11:0:operator:/root:/sbin/nologin
11:games:x:12:100:games:/usr/games:/sbin/nologin
12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
13:nobody:x:99:99:Nobody:/:/sbin/nologin
14:systemd-bus-proxy:x:999:997:systemd Bus Proxy:/:/sbin/nologin
15:systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
16:dbus:x:81:81:System message bus:/:/sbin/nologin
17:polkitd:x:998:996:User for polkitd:/:/sbin/nologin
18:tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
19:postfix:x:89:89::/var/spool/postfix:/sbin/nologin
20:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
21:chrony:x:997:995::/var/lib/chrony:/sbin/nologin
4.显示出那些行含有root,并将行号一块输出。
[root@web2 mnt]# grep -n 'root' passwd
1:root:x:0:0:root:/root:/bin/bash
10:operator:x:11:0:operator:/root:/sbin/nologin
5.显示出文件中
6.新建用户
abominable
abominate
anomie
atomize
编写正则表达式,将他们匹配出来
[root@web2 mnt]# egrep 'abominable|abominate|anomie|atomize' passwd
abominable:x:1001:1001::/home/abominable:/bin/bash
abominate:x:1002:1002::/home/abominate:/bin/bash
anomie:x:1003:1003::/home/anomie:/bin/bash
atomize:x:1004:1004::/home/atomize:/bin/bash
7.建四个用户
Alex213sb
Wpq2222b
yH438PIG
egon666
egon
过滤出用户名组成是字母+数字+字母的行
[root@web2 mnt]# egrep '[a-Z]+[0-9]+[a-Z]+' passwd
Alex213sb:x:1005:1005::/home/Alex213sb:/bin/bash
Wpq2222b:x:1006:1006::/home/Wpq2222b:/bin/bash
yH438PIG:x:1007:1007::/home/yH438PIG:/bin/bash
8.显示出/etc目录下所有包含root的文件名
9. 过滤掉/etc/ssh/sshd_config内所有注释和所有空行
[root@web2 mnt]# egrep -v '^#|^$' /etc/ssh/sshd_config
HostKey /etc/ssh/ssh_host_rsa_key
HostKey /etc/ssh/ssh_host_ecdsa_key
HostKey /etc/ssh/ssh_host_ed25519_key
SyslogFacility AUTHPRIV
AuthorizedKeysFile .ssh/authorized_keys
PasswordAuthentication yes
ChallengeResponseAuthentication no
GSSAPIAuthentication yes
GSSAPICleanupCredentials no
UsePAM yes
X11Forwarding yes
UsePrivilegeSeparation sandbox # Default for new installations.
AcceptEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
AcceptEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
AcceptEnv LC_IDENTIFICATION LC_ALL LANGUAGE
AcceptEnv XMODIFIERS
Subsystem sftp /usr/libexec/openssh/sftp-server
3.:sed作业:以/etc/passwd文件为模板
1,删除文件每行的第一个字符。
sed -r 's/^(.)(.*)/2/' passwd
2,删除文件每行的第二个字符。
sed -r 's/^(.)(.*)/2/' passwd
3,删除文件每行的最后一个字符。
sed -r 's/^(.)(.)(.*)/13/' passwd
4,删除文件每行的倒数第二个字符。
sed -r 's/(.*)+(.)(.)$/13/' passwd
5,删除文件每行的第二个单词。
6,删除文件每行的倒数第二个单词。
sed -r 's/([^a-Z])([a-Z]+)([^a-Z])([a-Z]+)$/134/' passwd
7,删除文件每行的最后一个单词。
sed -r 's/(.*)+([^a-Z])([a-Z]+)$/3/' passwd
8,交换每行的第一个字符和第二个字符。
sed -r 's/(.)(.)(.*)+/213/' passwd
9,交换每行的第一个字符和第二个单词。
sed -r 's/^(.)([a-Z]+)([^a-Z]+)([a-Z]+)(.*)+/1- 2-3 -4/' passwd
10,交换每行的第一个单词和最后一个单词。
sed -r 's/([a-Z]+)(.*)([^a-Z]+)([a-Z]+)$/4231/' passwd
11,删除一个文件中所有的数字。
sed -r '/[0-9]+//g' passwd
12,删除每行开头的所有空格。
sed -r 's/^ *//g' passwd
13,用制表符替换文件中出现的所有空格。
sed -r 's/ / /g' /etc/passwd
14,把所有大写字母用括号()括起来。
sed -r 's/[A-Z]/(&)/g' /etc/passwd
15,打印每行3次。
sed 'p;p' /etc/passwd
16,只显示每行的第一个单词。
sed '1~2d' /etc/passwd
17,打印每行的第一个单词和第三个单词。
18,用命令获取格式为 mm/yy/dd 的日期格式,结合管道,将其换成 mm;yy;dd格式