|
测试文本内容:[beyes@beyes sed]$ cat test.txt
Linux Sysadmin
Databases - Oracle, mySQL etc.
Security (Firewall, Network, Online Security etc)
Storage in Linux
Productivity (Too many technologies to explore, not much time available)
Windows- Sysadmin, reboot etc.
= 命令可以将当前行的行号打印到标准输出,基本语法如下:如果直接运行上面形式命令,那么将打印出所有行的行号:[beyes@beyes sed]$ sed '=' test.txt
1
Linux Sysadmin
2
Databases - Oracle, mySQL etc.
3
Security (Firewall, Network, Online Security etc)
4
Storage in Linux
5
Productivity (Too many technologies to explore, not much time available)
6
Windows- Sysadmin, reboot etc.
如果希望打印包含 Database 的行的行号,那么可以:[beyes@beyes sed]$ sed -n '/Database/=' test.txt
2
如果要打印匹配一个范围内的行的行号,那么可以:[beyes@beyes sed]$ sed -n '/Oracle/,/reboot/{
> =
> p
> }' test.txt
2
Databases - Oracle, mySQL etc.
3
Security (Firewall, Network, Online Security etc)
4
Storage in Linux
5
Productivity (Too many technologies to explore, not much time available)
6
Windows- Sysadmin, reboot etc. = 命令只接受一个地址的行号打印,如果像上面希望打印一个匹配范围内的行号时,= 命令必须用花括号括起来。另外,= 命令后的 p 命令是打印行内容,如果省略掉 p ,那么只打印行号。
我们经常通过 cat filename | wc -l 来统计一个文本的行数,现在使用 sed 的 = 命令也可以得到同样的结果,比如:[beyes@beyes sed]$ sed -n '$ =' test.txt
6 |
|