三剑客 sed

三剑客之一

经过三周的学习 ,今天来学习二 以及实验
sed
用法: 输入文件
sed [option]… ‘script’ inputfile…
常用选项:
-n:不输出模式空间内容到屏幕,即不自动打印
-e: 多点编辑
-f:/PATH/SCRIPT_FILE: 从指定文件中读取编辑脚本
-r: 支持使用扩展正则表达式
-i.bak: 备份文件并原处编辑 
script: ‘地址命令’

sed工具
 编辑命令:
d: 删除模式空间匹配的行,并立即启用下一轮循环
p:打印当前模式空间内容,追加到默认输出之后
a [\]text:在指定行后面追加文本 支持使用\n实现多行追加
i [\]text:在行前面插入文本
c [\]text:替换行为单行或多行文本
w /path/somefile: 保存模式匹配的行至指定文件
r /path/somefile:读取指定文件的文本至模式空间中 匹配到的行后
=: 为模式空间中的行打印行号
!:模式空间中匹配行取反处理
地址定界:
(1) 不给地址:对全文进行处理
(2) 单地址: #: 指定的行,$:最后一行 /pattern/:被此处模式所能够匹配到的每一行
(3) 地址范围: #,# #,+# /pat1/,/pat2/ #,/pat1/
(4) ~:步进 1~2 奇数行 2~2 偶数行

sed工具
 编辑命令:
d: 删除模式空间匹配的行,并立即启用下一轮循环
p:打印当前模式空间内容,追加到默认输出之后
a [\]text:在指定行后面追加文本 支持使用\n实现多行追加
i [\]text:在行前面插入文本 c [\]text:替换行为单行或多行文本
w /path/somefile: 保存模式匹配的行至指定文件
r /path/somefile:读取指定文件的文本至模式空间中 匹配到的行后
=: 为模式空间中的行打印行号
!:模式空间中匹配行取反处理

sed工具
s///:查找替换,支持使用其它分隔符,s@@@,s### 替换标记:
g: 行内全局替换
p: 显示替换成功的行
w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中

高级编辑命令
P:打印模式空间开端至\n内容,并追加到默认输出之前 h: 把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g: 从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x: 把模式空间中的内容与保持空间中的内容进行互换 n: 读取匹配到的行的下一行覆盖至模式空间
N:读取匹配到的行的下一行追加至模式空间
d: 删除模式空间中的行
D:如果模式空间包含换行符,则删除直到第一个换行符的模式空间中的文本, 并不会读取新的输入行,而使用合成的模式空间重新启动循环。如果模式空间 不包含换行符,则会像发出d命令那样启动正常的新循环

实验:

意思是打印第二行 其余的显示
[root@centos7 ~]#sed -n ‘2p’
dd
aaa
aaa
ccc

打印以U开头的显示
[root@centos7 ~]#cat /etc/fstab
# Accessible filesystems, by reference, are maintained under ‘/dev/disk’
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
/dev/mapper/centos_centos7-root / xfs defaults 0 0
UUID=9f54d0d3-f4c1-4f7b-a6af-fcd3db6993d8 /boot xfs defaults 0
/dev/mapper/centos_centos7-data /data xfs defaults 0 0
/dev/mapper/centos_centos7-swap swap swap defaults 0 0
[root@centos7 ~]#sed -n ‘/^U/p’ /etc/fstab
UUID=9f54d0d3-f4c1-4f7b-a6af-fcd3db6993d8 /boot xfs defaults 0 0

显示dev下sd开头 注意下 /^/dev/sd/p 这样写话 前面斜线和后面斜线表示正则表达示 中间的表示就hi是/ 那么需要软意 /^\/dev\/sd/p

[wen@localhost ~]$ ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:0C:29:EA:D8:5E
只想打印 inet addr:192.168.214.133 Bcast:192.168.214.255 Mask:255.255.255.0
inet6 addr: fe80::20c:29ff:feea:d85e/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:2561 errors:0 dropped:0 overruns:0 frame:0
[wen@localhost ~]$ ifconfig eth0 |sed -n ‘/\<inet\>/p’
inet addr:192.168.214.133 Bcast:192.168.214.255 Mask:255.255.255.0

[wen@localhost ~]$ df
Filesystem 1K-blocks Used Available Use% Mounted on
/dev/sda2 203988800 2710692 190909340 2% /
tmpfs 501508 72 501436 1% /dev/shm
/dev/sda1 289293 34881 239052 13% /boot
[wen@localhost ~]$ df | sed -n ‘/^\/dev\/sd/p’
/dev/sda2 203988800 2710692 190909340 2% /
/dev/sda1 289293 34881 239052 13% /boot

在quiet 后面加abc

[root@centos7 ~]#cat /etc/default/grub
GRUB_TERMINAL_OUTPUT=”console”
GRUB_CMDLINE_LINUX=”crashkernel=auto rd.lvm.lv=centos_centos7/root rd.lvm.lv=centos_centos7/swap rhgb quiet”
GRUB_DISABLE_RECOVERY=”true”
[root@centos7 ~]#sed -r ‘/LINUX/s/”$/ abc”/’ /etc/default/grub
GRUB_DISABLE_SUBMENU=true
GRUB_TERMINAL_OUTPUT=”console”
GRUB_CMDLINE_LINUX=”crashkernel=auto rd.lvm.lv=centos_centos7/root rd.lvm.lv=centos_centos7/swap rhgb quiet abc”
GRUB_DISABLE_RECOVERY=”true”

用sed提取ip地址 用到分组 和 正则表达式

[wen@localhost ~]$ ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:0C:29:EA:D8:5E
inet addr:192.168.214.133 Bcast:192.168.214.255 Mask:255.255.255.0
inet6 addr: fe80::20c:29ff:feea:d85e/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:4369 errors:0 dropped:0 overruns:0 frame:0
TX packets:885 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:292975 (286.1 KiB) TX bytes:87258 (85.2 KiB)

[wen@localhost ~]$ ifconfig eth0 |sed -rn ‘2s/(.* addr:)(.*)(Bcast.*)/\2/p’
192.168.214.133
[wen@localhost ~]$ ifconfig eth0 |sed -rn ‘2s/(.* addr:)(.*)(Bcast.*)/\3/p’
Bcast:192.168.214.255 Mask:255.255.255.0
[wen@localhost ~]$ ifconfig eth0 |sed -rn ‘2s/(.* addr:)(.*)(Bcast.*)/\1/p’
inet addr:

取基名

[root@centos7 ~]#echo “/etc/sysconfig/network-scripsts/”
/etc/sysconfig/network-scripsts/
[root@centos7 ~]#echo “/etc/sysconfig/network-scripsts/” |sed -r ‘s#(^.*/)([^/]+/?$)#\2#’
network-scripsts/

给前面加#

[wen@localhost ~]$ vim /etc/httpd/conf/httpd.conf |sed -r ‘s/^[^#]/#&/’
Vim: Warning: Output is not to a terminal
#
DAVLockDB /var/lib/dav/lockdb
#</IfModule>
#
##
# ScriptAlias: This controls which directories contain server scripts.
# ScriptAliases are essentially the same as Aliases, except that
# documents in the realname directory are treated as applications and
# run by the server when requested rather than as documents sent to the client.
# The same rules about trailing “/” apply to ScriptAlias directives as to
# Alias.
#

取版本号

[root@centos7 ~]#cat /etc/centos-release
CentOS Linux release 7.5.1804 (Core)
[root@centos7 ~]#cat /etc/centos-release | sed -r ‘s/[^[:digit:]]+([0-9]+).*/\1/’7

 

查看linux内核有多少行
[root@centos7 ~]#cat ‘find linux-4.17.11 -name “.*c” |wc -l
17844326

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/104659

(0)
初来乍到初来乍到
上一篇 2018-08-07 01:12
下一篇 2018-08-08 00:19

相关推荐

  • 华为交换机配置

    示例设备华为s5700S-28P-LI-AC 用户视图<HUAWEI>:默认登录 系统视图[HUAWEI]:system-view 接口视图[HUAWEI-GigabitEthernetX/Y/Z]:interface gigabitethernet X/Y/Z X/Y/Z为需要配置的接口的编号,分别对应“槽位号/子卡号/接口序号” 路由协议视图…

    Linux笔记 2018-06-07
  • Linux用户与组管理命令的易混淆点和重合点

    Linux用户与组的管理命令,对于初学者来说很容易造成混淆,此外,这些命令之间有很多相重合的用法,即:拥有多种命令可实现相同的需求的情况。

    2018-04-03
  • securceCRT网络连接不正常解决途径

    本文中centos版本为6.9

    2018-04-01
  • SSH协议及基于SSH集群key认证实验

    本节索引: 一、SSH协议相关概念 二、实验:实现基于key登录认证 三、实验:实现多台机器间互相基于key登录认证 四、实验:实现100台机器基于key登录验证 五、实验:利用pssh工具实现集群操作 一、SSH协议相关概念 SSH:secure shell,protocal,22/tcp,安全的远程登录; 利用 SSH 协议可以有效防止远程管理过程中的信…

    2018-05-19
  • 挂载点 文件通配符 目录的一些理解

    挂载点 挂载点实际上就是linux中的磁盘文件系统的入口目录,类似于windows中的用来访问不同分区的C:、D:、E:等盘符。其实Windows也支持将一个磁盘分区挂在一个文件夹下面,只是我们用C:、D:这样的盘符操作用惯了,一般没有将分区挂到文件夹。文件一般挂载在misc文件夹下 在我们打开Centos 6(并未登录)时在远程控制台是不能看到挂载点的如图…

    2018-04-01
  • Linux基础命令与bash基础特性

    第二周作业

    2018-05-19