sed

sed 过滤文件改文 ( 行编辑器)
Sed 选项 脚本(地址命令)inputfile(要处理的文件名)
-n 不输出模式空间内容到屏幕,即不自动打印
-e 多点编辑
-f /PATH/SCRIPT_FILE: 从指定文件中读取编辑脚本
-r支持使用扩展正则表达式
-i.bak 备份文件并远处编辑 -i编辑文件不备份
script ‘地址命令’
不给地址: 对全部的所有行处理
单地址:# 指定的行(数字),$最后一行
/pattern/ 被此模式匹配到的每行
地址范围 : #,#
#,+#
/pat1/,/pat2/
#,/pat1/
~:步进
1~2奇数行
2~2偶数行
编辑命令
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:将替换成功的行保存至文件中

sed ‘2,5a\ ===’ f2 把f2文件2-5行添加‘空===’
sed -r ‘s/(root)/\1er/g’ /etc/passwd 在/etc/passwd全局搜索root替代为rooter相当于在root后插入er
sed -r ‘s/(root)/admin\1/g’ /etc/passwd在/etc/passwd全局搜索root替代为adminroot相当于在root前面插入admin
ifconfig ens33|sed -r ‘s@.*inet (.*) netmask.*@\1@’|sed -n ‘2p’显示IP地址

sed ‘/^#<VirtualHost/,/^#</s/#//’ /etc/httpd/conf/httpd.conf|sed -r ‘s@#(Name.*)@\1@’
sed -re ‘s@#(Name.*)@\1@’ -e ‘/^#<VirtualHost/,$s/#//’ /etc/httpd/conf/httpd.conf同上
echo “/etc/sysconfig/network/”|sed -r ‘s@(.*\/)([^/]+\/?$)@\1@”显示路径 \2显示基名

sed示例
sed ‘2p’ /etc/passwd 打印第二行
sed –n ‘2p’ /etc/passwd 只打第二行
sed –n ‘1,4p’ /etc/passwd 只打印第1-4行
sed –n ‘/root/p’ /etc/passwd 只打印包含root的行
sed –n ‘2,/root/p’ /etc/passwd 从2行开始 (只打印从第2行到包含root的行)
sed -n ‘/^$/=’ file 显示空行行号
sed –n –e ‘/^$/p’ –e ‘/^$/=’ file 显示空行并打印行号
sed ‘/root/a\superman’ /etc/passwd行后 (在包含root的行后面加上字符串)
sed ‘/root/i\superman’ /etc/passwd 行前
sed ‘/root/c\superman’ /etc/passwd 代替行 (用字符串代替包含root的行)

sed ‘/^$/d’ file 删除空行
sed ‘1,10d’ file 删除1-10行
nl /etc/passwd | sed ‘2,5d’ 显示行号并删除2,-5行
nl /etc/passwd | sed ‘2a tea’ 显示行号并在第二行后加tea
sed ‘s/test/mytest/g’ example 搜索test用mytest替代(全文搜索g)
sed –n ‘s/root/&superman/p’ /etc/passwd 单词后 {在单词root后插入superman并打印(&表示前面搜索的字符串root)}
sed –n ‘s/root/superman&/p’ /etc/passwd 单词前
sed -e ‘s/dog/cat/’ -e ‘s/hi/lo/’ pets 多点替换(把dog替换成cat,把hi替换成lo)
sed –i.bak ‘s/dog/cat/g’ pets 搜索后改文件{(-i).bak备份一份}

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

(0)
张陆禄张陆禄
上一篇 2018-04-15
下一篇 2018-04-15

相关推荐

  • mysql

    yum安装 1、yum install mysql-server /var/lib/mysql 用户存放的位置 2、chkconfig –list mysqld 查看是否启动 3、chkconfig mysqld on 设置为开机启动 4、ss -ntl;service mysqld start 开启服务 端口号为3306 /!可以执行linux…

    Linux笔记 2018-06-14
  • 自建yum仓库,分别为网络源和本地源

    [base] name=CDRom baseurl=file:///mnt gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7 [CentOS] name=CentOS.org baseurl=http://vault.centos.org/7.4.1708/os/x86_64/ enabled=1 gpg…

    Linux笔记 2018-06-07
  • 两台主机之间搭建路由通信

    搭建路由通信

    2018-04-29
  • liunx 创建用户、文件权限及管理

      创建用户     修改和删除组 更改组密码 更改和查看组成员 文件权限:文件属性 文件属性操作 修改文件的属性和属组 文件权限   文件权限 八进制数字: 修改用户权限:   新建文件和目录的默认权限:               &n…

    Linux笔记 2018-04-08
  • linux与xshell入门

    难的不行,做标记

    2018-07-29
  • Linux用户和组

    我们知道Linux是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统。由于是多用户操作系统,必然要涉及到时管理用户。由于用户访问Linux上的资源比较多,为了方便管理出现的组的概念.将多个用户添加到一个组里,方便管理。 介绍安全3A 资源分派: Authentication:认证 Au…

    Linux笔记 2018-04-08