正则表达式

---恢复内容开始---

/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.bak
4.显示出那些行含有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/^(.)(.)(.*)/13/g' /tmp/passwd.bak
3,删除文件每行的最后一个字符。

sed -r 's/(.*)(.)$/1/' /tem/passwd.bak

4,删除文件每行的倒数第二个字符。

sed -r 's/(.*)(.)(.)$/13/' /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

原文地址:https://www.cnblogs.com/amiee-785563694/p/6601645.html