sed使用小命令及课后作业

Stream EDitor,  行编辑器

sed 是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space ),接着用sed 命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed 主要用来自动编辑一个或多个文件, 简化对文件的反复操作, 编写转换程序等

实用选项及用法:


sed -n “p” f1 :只打印地址p一次 (不加n会打印两次)

sed -n “2p” f1:只打印第二行内容
cat -n |sed -n “3,10p”f1 :显示3,10行内容
cat -n |sed -n “3,10p”f1 显示3,13行内容
cat -n |sed -n ‘/root/p’ f1:包含root的行(使用正则表达式模式)
sed -n ‘/^/ ,/ ^/p’ f1 :显示已某个单词开头到已某个单词开头的行 铆钉行首
sed -n ’10 ,/ ^/p’ f1 :显示第十行到某个单词开头的行
sed -n ‘1~2p’ f1 :打印奇数行
sed -n ‘2~2p‘ f1:打印偶数行
sed ‘2~2d’ f1 :删除偶数行
sed ’20a…….’f1 :在第20行后面增加内容…….
sed ’20a\ …….\n,,,,,,,,,,’f1 :在第20行后面增加内容…….并且前面显示以空格分开,并且进行换行再显示,,,,,
sed ’10,20i\ …….\n,,,,,,,,,,’f1:在第10-20行前面增加内容…….并且前面显示以空格分开,并且进行换行再显示,,,,,
sed ’10,20c\ …….\n,,,,,,,,,,’f1:使用后面的三段符号替代10-20行内容
sed -i.conf ’10d’ f1 :删除第10行并提前备份f1 文件名称一个以.cof结尾,如果不在i后面加.conf 那直接破坏文件,删除第十行并保存。
sed ‘1-6=’ :1-6行打印行号
sed -n ‘2~2!p‘ f1 :取反,只取单数
sed ‘s/root/ROOT/g’ f1:把文件中的root全部替换成大写,不加g只替换第一个
sed -n ‘s/root/ROOT/gpw /root/f22’ f1:把文件中的root全部替换成大写,并把显示行打印出来,并把更改的行重新保存到一个文件里面。
sed ‘/^$/d’ :删除空行

应用作业

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

#cat f3 | sed ‘s/^[[:space:]]\+//g’
2 、删除/etc/fstab 文件中所有以# 开头,后面至少跟一个空白字符的行的行首的# 和空白字符
cat /etc/fstab |sed -r ‘s@^#[ :space: ]?@@g’
3 、在centos6 系统/root/install.log 每一行行首增加#号 号
#cat /root/install.log|sed -r “s/(^[^#])/#&/”
4 、在/etc/fstab 文件中不以# 开头的行的行首增加#号 号
cat /etc/fstab|sed -r “s/(^[^#])/#&/”
5 、处理/etc/fstab 路径, 使用sed 命令取出其目录名和基名
#echo ‘/etc/fstab’ |sed -r ‘s@(/.*/)(/?.*)@\2@g’
echo ‘/etc/fstab’ |sed ‘s@/.*/@@g’
echo ‘/etc/fstab’ |sed -r ‘s@(/.*/)?.*@\1@g’
6 、利用sed 取出ifconfig 命令中本机的IPv4 地址
# ifconfig eth0 |sed -n ‘2p’ |sed ‘s/^.*addr://’|sed ‘s/B.*//’
7 、统计centos 安装光盘中Package 目录下的所有rpm 文件的以 以. 分隔倒数第二个字段的重复次数
ls /run/media/root/CentOS\ 7\ x86_64/Packages/ |rev|cut -d. -f2 |rev|sort |uniq -c
ls /run/media/root/CentOS\ 7\ x86_64/Packages/ |sed -r ‘s@.*\.(.*)\.rpm@\1@’|sort|uniq -c
8 、统计/etc/init.d/functions 文件中每个单词的出现次数,并排序(用grep 和sed 两种方法分别实现)
cat /etc/init.d/functions |grep -o ‘.’|sort|uniq -c
cat /etc/init.d/functions |sed ‘s@.@\n&@g’|sort|uniq -c

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

(0)
fujunlongfujunlong
上一篇 2017-03-18 18:18
下一篇 2017-03-19

相关推荐

  • 用户及相关权限命令

    2018-03-26

    2018-03-26
  • RPM程序包管理

           RPM的全名“RedHat Package Manager”,当初这个是RedHad公司开发的一款程序包管理套件,随着RPM的不断完善,RPM逐渐成为众多linux发行版程序包管理器的代名词,那什么是RPM,为什么会用到RPM这个程序包管理工具那,接下来我一一揭晓。  &nb…

    Linux干货 2015-11-04
  • 让运维工程师不再蓝瘦、香菇

    最近广西一小哥失恋后录的视频风靡互联网,也让“蓝瘦、香菇”这两个词火了一把。虽然原故事男主角是因为失恋才蓝瘦、香菇,但想想作为运维“狗”的我们也时常因强大的工作压力而蓝瘦,常常在晚上睡得香呼呼的时候因为要处理故障从温暖的被窝爬起来,看着铝朋友鄙视的眼神,真的好香菇……本来作为技术大牛的我们,工作应该是很酷的事情,享受的应该是小白美铝们崇拜的眼神,可现在却那么…

    系统运维 2017-01-09
  • 马哥教育网络班21期+第4周课程练习

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@centos ~]# cp -r /etc/skel /home/tuser1 [root@centos ~]# ls -aldh&…

    Linux干货 2016-07-29
  • linux 加密和证书

    安全目标:机密性:明文传输的ftp, http,telnet 不安全数据完整性:身份验证:可用性:安全技术:认证,授权,安全通信,审计密码算法和协议:对称加密,公钥加密,单向加密,认证协议 1、对称加密:加密,解密使用同一个秘钥,效率高 DES:Data Encrption Standard, 56bit3DES:AES:AdvancedBlowfish缺点…

    2017-09-11
  • 基于kubernetes构建Docker集群管理详解

    一、前言        Kubernetes 是Google开源的容器集群管理系统,基于Docker构建一个容器的调度服务,提供资源调度、均衡容灾、服务注册、动态扩缩容等功能套件,目前最新版本为0.6.2。本文介绍如何基于Centos7.0构建Kubernetes平台,在正式介绍…

    2015-03-10