正则表达式
---恢复内容开始---
/etc/profile----------------可添加path,以登陆的方式才会加载此文件
/etc/bashrc-----------------
/root/.basharc
/root/.bash_profile
grep 过滤
-n----显示行号
-E---egrep 扩展正则表达式
-l---如果匹配成功,则只将文件名打印出来,失败则不打印,通常-rl一起用
^----------以什么开头----上阶号
$--------以什么结尾
.-----------任意一个字符
*-----------左边的字符有0个或无穷个------ab*
+----------左边的字符至少有一个或无穷个------ab+
{n}----------左边有n个字符ab{3}*-------ab{2,6}
?----------左边的字符出现0次或1次
'[abcde]'-------取大括号中间的任意一个
|----------或的意思
[a-z]----------所以的小写字母
[A-Z]---------所以的大写字母
[a-z][A-Z]------所有的大写小写字母
^ *$----------表示空行
如果-当做字符本身使用的话,必须放后面[asadasd\-]
sed 流编辑器
-n-------不打印默认的输出文件 用echo $?查看
-i--------会修改文件
-f--------
sed ‘’
1d----删除第一行
2c----修改第二行
3p----打印第三行
4a----第四行添加
awk-------
-F----后面可加分隔符
awk -F: '{print $1}'
$NF---取最后一段字符
NR----带行号显示
正则表达式及字符处理 目标文件/etc/passwd,使用grep命令或egrep 1.显示出所有含有root的行:
egrep 'root' /tmp/passwd.bak 2.输出任何包含bash的所有行,还要输出紧接着这行的上下各两行的内容:
egrep -C2 'bash' /tmp/passwd.bak 3. 显示出有多少行含有nologin。
egrep -c 'nologin' /tmp/passwd.bak4.显示出那些行含有root,并将行号一块输出。
egrep -n 'root' /tmp/passwd.bak
5.显示出文件名
6.新建用户 abominable abominate anomie atomize 编写正则表达式,将他们匹配出来 egrep 'a.omi(nabl|nat|z|)e' /etc/passwd 7.建四个用户 Alex213sb Wpq2222b yH438PIG egon666 egon
过滤出用户名组成是字母+数字+字母的行
egrep -i '[a-Z]+[0-9]+[a-Z]' /tmp/passwd.bak
Sed作业:以/etc/passwd文件为模板
1,删除文件每行的第一个字符。
sed -r 's/^(.)(.*)/\2/g' /tmp/passwd.bak
2,删除文件每行的第二个字符。
sed -r 's/^(.)(.)(.*)/\1\3/g' /tmp/passwd.bak
3,删除文件每行的最后一个字符。
sed -r 's/(.*)(.)$/\1/' /tem/passwd.bak
4,删除文件每行的倒数第二个字符。
sed -r 's/(.*)(.)(.)$/\1\3/' /tem/passwd.bak
5,删除文件每行的第二个单词。
6,删除文件每行的倒数第二个单词。
7,删除文件每行的最后一个单词。
8,交换每行的第一个字符和第二个字符。
9,交换每行的第一个字符和第二个单词。
10,交换每行的第一个单词和最后一个单词。
11,删除一个文件中所有的数字。 12,删除每行开头的所有空格。 13,用制表符替换文件中出现的所有空格。 14,把所有大写字母用括号()括起来。 15,打印每行3次。 16,隔行删除。 17,把文件从第2行到第5行复制到第7行后面。(选做题) 18,把文件从第2行到第5行移动到第7行后面。(选做题) 19,只显示每行的第一个单词。 20,打印每行的第一个单词和第三个单词。 21,将格式为 mm/yy/dd 的日期格式换成 mm;yy;dd 22, a.txt内容 ABC DEF XYZ 通过SED实现tac命令 tac a.txt XYZ DEF ABC
---恢复内容结束---
sed -r 's/^(.)(.*)/\2/g' /tmp/passwd.bak