博客
关于我
linux环境sed命令实例学习
阅读量:798 次
发布时间:2019-03-24

本文共 1652 字,大约阅读时间需要 5 分钟。

SED命令简介

SED(Stream Editor)被称为流编辑器,是Linux命令环境中“三剑客”之一,功能强大,能够根据命令处理数据流中的数据。命令可以在命令行中执行,也可以从文本文件中读取。

SED的工作流程如下:

  • 一次从输入中读取一行数据
  • 根据提供的编辑命令匹配数据 3.按照命令修改数据 4.将修改后的数据输出到标准输出
  • 所有命令处理完一行数据后,SED会读取下一行数据重复上述过程,直到处理完所有数据后终止。

    必备知识

    正则表达式是SED命令的核心,是描述匹配规则的语言。掌握正则表达式是使用SED的关键。

    测试环境

    CentOS 7.x

    具体实例

    以下实例来自网络整理,仅供学习参考,实际操作需根据不同文本文件环境进行调整。

    打印

  • 打印第一行

    sed -n '1p' passwd

  • 打印最后一行

    sed -n '$p' passwd

  • 打印第三行

    sed -n '3p' passwd

  • 打印第三行到第八行

    sed -n '3,8p' passwd

  • 打印第三行和第5行

    sed -n '3p;5p' passwd

  • 打印第三行和第五号到第八行

    sed -n '3p;5,8p' passwd

  • 打印奇数行

    sed -n 'p;n' passwd

  • 打印偶数行

    sed -n 'n;p' passwd

  • 打印每行3次

    sed 'p;p' passwd
    sed -n 'p;p;p' passwd

  • 打印以mail开始的行

    sed -n '/^mail/p' passwd

  • 删除

  • 删除空白行(打印非空行)

    sed '/^$/d' passwd
    grep -v "^$" passwd
    awk '{if($0!="") print}' passwd
    awk '{if(length!=0) print}' passwd
    cat passwd | tr -s '\n'

  • 删除第二行

    sed '2d' passwd

  • 删除第二行到第五行

    sed '2,5d' passwd

  • 删除第二行和第五行到第八行

    sed '2d;5,8d' passwd

  • 删除最后一行

    sed '$d' passwd

  • 删除奇数行

    sed '1d;n;d' passwd
    sed '1~2d' passwd

  • 删除偶数行

    sed '2d;n;d' passwd
    sed '2~2d' passwd

  • 替换

  • 用制表符替换文件中的空格

    sed -r 's/ /\t/g' passwd

  • 把所有小写字母用括号括起来

    sed 's/[a-z]/(&)/g' passwd
    (用&代表匹配到的字母)

  • 将格式2018/12/31换成2018-12-31

    echo "2018/12/31" | sed 's#/#-#g'

  • 将文件中所有的root单词替换成大写的ROOT

    sed 's/\<root\>/ROOT/g' passwd

  • 交换(替换思想)

  • 交换每行的第一个字符和第二个单词

    sed -r 's/^(.)([^a-Z]*)([a-Z]+)([^a-Z]+)([a-Z]+)/\5\2\3\4\1/' /etc/passwd

  • 交换每行的第一个单词和最后一个单词

    sed -r 's/([^a-Z]*)([a-Z]+)([^a-Z]+)(.*)([^a-Z]+)([a-Z]+)/\1\6\3\4\5\2/' passwd

  • 交换每行的倒数第二个单词和最后一个单词

    sed -r 's/([^a-Z]+)([a-Z]+)([^a-Z]+)([a-Z]+)([^a-Z]*)$/\1\4\3\2\5/' passwd

  • 插入(i\,a\)

  • 在第一行上插入

    sed '1i at the top' passwd

  • 在匹配行上插入

    sed '/^the/i I am here' passwd

  • 在第二行下面插入

    sed '2a I am here' passwd

  • 在最后一行下面插入

    sed '$a at the bottom' passwd

  • 转载地址:http://foyuk.baihongyu.com/

    你可能感兴趣的文章
    Mysql group by
    查看>>
    MySQL I 有福啦,窗口函数大大提高了取数的效率!
    查看>>
    mysql id自动增长 初始值 Mysql重置auto_increment初始值
    查看>>
    MySQL in 太多过慢的 3 种解决方案
    查看>>
    Mysql Innodb 锁机制
    查看>>
    MySQL InnoDB中意向锁的作用及原理探
    查看>>
    MySQL InnoDB事务隔离级别与锁机制深入解析
    查看>>
    Mysql InnoDB存储引擎 —— 数据页
    查看>>
    Mysql InnoDB存储引擎中的checkpoint技术
    查看>>
    Mysql InnoDB存储引擎中缓冲池Buffer Pool、Redo Log、Bin Log、Undo Log、Channge Buffer
    查看>>
    MySQL InnoDB引擎的锁机制详解
    查看>>
    Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
    查看>>
    mysql InnoDB数据存储引擎 的B+树索引原理
    查看>>
    mysql interval显示条件值_MySQL INTERVAL关键字可以使用哪些不同的单位值?
    查看>>
    mysql problems
    查看>>
    MySQL replace函数替换字符串语句的用法(mysql字符串替换)
    查看>>
    mysql workbench6.3.5_MySQL Workbench
    查看>>
    MySQL Workbench安装教程以及菜单汉化
    查看>>
    MySQL Xtrabackup 安装、备份、恢复
    查看>>
    mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
    查看>>