sed使用小结

sed使用小结

Stream EDitor  行编辑器 

     sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”( pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变 ,除非你使用重定向存储输出。

     sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等

 

用法: sed [option]… 'script' inputfile… 

 

地址定界: 

(1) 不给地址:对全文进行处理 

(2) 单地址: #: 指定的行 /pattern/:被此处模式所能够匹配到的每一行 

(3) 地址范围: #,# 

#,+# 

/pat1/,/pat2/

 #,/pat1/ 

(4) ~:步进 

1~2 奇数行 

2~2 偶数行

f1.png

 

 

编辑命令: 

d: 删除模式空间匹配的行 

p: 显示模式空间中的内容 

a \text:在行后面追加文本;支持使用\n实现多行追加 

i \text:在行前面插入文本;支持使用\n实现多行插入 

c \text:替换行为单行或多行文本 

w /path/to/somefile: 保存模式匹配的行至指定文件 

r /path/from/somefile:读取指定文件的文本至模式空 间中匹配到的行后 

=: 为模式空间中的行打印行号 

!:模式空间中匹配行取反处理

 

s///:查找替换,支持使用其它分隔符,s@@@s### 

替换标记: g: 行内全局替换 

p: 显示替换成功的行 

w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中

 

1、删除/etc/grub2.conf文件中所有以空白开头的行行首的空白字符 

     sed -r "s@^[[:space:]]+@@" /etc/grub2.cfgv

2、删除/etc/fstab文件中所有以#开头,后面至少跟一个空 白字符的行的行首的#和空白字符

               sed -r "s@^#[[:space:]]+@@" /etc/fstab 

 3、在/root/install.log每一行行首增加#号 

          vsed -r "s@^@#" /root/install.log

4、/etc/fstab文件中不以#开头的行的行首增加#号 

  f2.png

v

5、处理/etc/fstab路径,使用sed命令取出其目录名和基名 v

f3.png

6、利用sed 取出ifconfig命令中本机的IPv4地址

  vf4.png

 

7、统计centos安装光盘中Package目录下的所有rpm文件的 以.分隔倒数第二个字段的重复次数

f5.png

 

 

 高级编辑命令:

h: 把模式空间中的内容覆盖至保持空间中 

H:把模式空间中的内容追加至保持空间中 

g: 从保持空间取出数据覆盖至模式空间 

G:从保持空间取出内容追加至模式空间 

x: 把模式空间中的内容与保持空间中的内容进行互换 

n: 读取匹配到的行的下一行覆盖至模式空间 

N:追加匹配到的行的下一行至模式空间 

d: 删除模式空间中的行 

D:删除当前模式空间开端至\n的内容(不在传至标准输 出),放弃之后的命令,但是对剩余模式空间重新执行sed

原创文章,作者:liuzhuo,如若转载,请注明出处:http://www.178linux.com/33703

(0)
liuzhuoliuzhuo
上一篇 2016-08-12 09:01
下一篇 2016-08-12 09:01

相关推荐

  • N25第一周作业

    1.描述计算机的组成及其功能   计算机整体上分为两大部分:     一、硬件部分:运算器,存储器,控制器,输入设备,输出设备     运算器是对数据进行加工处理,主要是指各种算术运算与逻辑运算     存储器是存储各种数据、信号、命令等信息并在他们需要时提供这些信息 &nbsp…

    Linux干货 2016-12-03
  • 第四周作业

    cp、grep、sueradd、chmod、vim命令的一些用法

    Linux干货 2017-12-24
  • 推荐-使用iptables作为网络防火墙构建安全的网络环境

    使用iptables作为网络防火墙构建安全的网络环境 使用iptables作为网络防火墙构建安全的网络环境 前言 网络防火墙的优势 实验拓扑图 实验环境 实验步骤 防火墙未设置前对所有服务器的测试 针对不同服务器进行”非法”访问 定义网络防火墙规则 再次针对不同服务器进行”非法”访问 测试服务器是否可访问 总结 前言 一般情况下iptables只作为主机防火…

    Linux干货 2016-03-31
  • 配置路由实例

    路由的分类和管理 路由:跨网络通信; 路由分类:     主机路由     网络路由     默认路由 路由管理命令: route 命令是在本地 IP 路由表中显示和修改条目网络命令; 查看:route -n 添加:route add ro…

    Linux干货 2016-09-12
  • 最简单的Linux系统——更加深入了解Linux启动过程

    自制一个最简单的Linux: 1、有一个新的磁盘,并创建分区 2、挂载分区,创建目录 3、拷贝内核文件 4、创建MBR和grub.conf文件 5、创建/etc/fstab文件,设置开机自动挂载 6、拷贝一个bash程序 7、卸载分区,以新磁盘重启系统

    Linux干货 2016-09-11
  • 创建私有CA及dropbear的编译安装

    使用openssl创建私有CA 配置文件/etc/pki/tls/openssl.cnf certs           = $dir/certs         &nb…

    Linux干货 2016-09-26