博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sed命令详解
阅读量:6840 次
发布时间:2019-06-26

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

sed命令:

  • 文本处理三剑客:
    • grep,egrep,fgrep:文本过滤工具
    • sed:stream editor,流编辑器,行编辑
    • awk:文本格式化工具,报告生成器
  • 工作方式

 

  • sed [OPTION]... 'script' [input-file]...
    • script:地址定界编辑命令
    • 常用选项
      • -n:不输出模式空间中的内容到屏幕
      • -e script,--expression=script:多点编辑
      • -f /PATH/TO/SED_SCRIPT_FILE
        • 每行一个编辑命令
      • -r,--regexp-extended:支持使用扩展正则表达式
      • -i[SUFFIX],--in-place[=SUFFIX]:直接编辑源文件
    • 地址定界:
      • 空地址:对全文进行处理
      • 单地址:
        • #:指定行
        • /pattern/:被此模式所匹配到的每一行
      • 地址范围:
        • #,#:从哪一行到哪一行
        • #,+#:首行,加偏移量
        • #,/pattern/
        • /pattern1/,/pattern2/
        • $:最后一行
      • 步进:~
        • 1~2:所有奇数行
        • 2~2:所有偶数行
    • 编辑命令:
      • d:删除
      • p:打印,与d相反
      • a \text:在行后面追加文本“text”,支持使用\n实现多行追加
      • i \text:在行前面插入文本"text",支持使用\n实现多行插入
      • c \text:把匹配到的行替换为此处指定的文本“text”
      • w /PATH/TO/SOMEFILE:保持模式空间匹配到的行至指定的文件中
        • 例子:sed -n '/^[^#]/w /tmp/fstab.new' /etc/fstab,保存非井号开头的行
      • r /PATH/FROM/SOEMFILE:读取指定文件的内容至当前文件被模式匹配到的行处
      • =:为模式匹配到的行打印行号
      • !:条件取反
        • 例子:sed -n '/^#/!w /tmp/fstab.new' /etc/fstab,保存非井号开头的行
      • s///:查找替换,其分隔符可自行指定,常用的有s@@@,s###等
        • 替换标记:
          • g:全局替换
          • w /path/to/somefile:将替换成功的结果保存至指定文件中
          • p:显示替换成功的行
        • 练习1:删除/boot/grub/grub2.cfg文件中所有以空白字符开头的行的行首的所有空白符
          • sed ' s@^[[:space:]]\+@@' /boot/grub/grub2.cfg
        • 练习2:删除/etc/fstab文件中所有以#开头的行的行首的#号及#后面的所有空白字符
          • sed ' s@^#[[:space:]]*@@' /etc/fstab
        • 练习3:输出一个绝对路径给sed命令,取出其目录,其行为类似于dirname
          • echo "/var/log/messages" | sed ' s@[^/]\+/\?$@@'
          • 疑问:扩展正则表达式中,+和?前面不需要加\
    • 高级编辑命令:
      • h:把模式空间中的内容覆盖至保持空间中
      • H:把模式空间中的内容追加至保持空间中
      • g:把保持空间中的内容覆盖至模式空间中
      • G:把保持空间中的内容追加至模式空间中
      • x:把模式空间中的内容与保持空间中的内容互换
      • n:覆盖读取匹配到的行的下一行至模式空间中
      • N:追加读取匹配到的行的下一行至模式空间中
      • d:删除模式空间中的行
      • D:删除多行模式空间中的所有行
      • 例子:
        • sed -n 'n;p' FILE:显示偶数行
        • sed '1!G;h;$!d' FILE:逆序显示文件内容
        • sed '$!d' FILE:取出最后一行
        • sed '$!N;$!D' FILE:取出文件最后两行
        • sed '/^$/d;G' FILE:删除原有的所有空白行,而后为所有的非空白行后添加一个空白行
        • sed 'n;d' FILE:显示奇数行
        • sed 'G' FILE:在原有的每一行后面添加一个空白行

转载于:https://www.cnblogs.com/jacky1982/p/8457534.html

你可能感兴趣的文章
hadoop作业分片处理以及任务本地性分析(源码分析第一篇)
查看>>
又睡不着了。。
查看>>
RHEL在VLAN Trunk模式下的IP地址配置
查看>>
RHCE 学习笔记(38 ) - Shell
查看>>
WEB服务器-Nginx之虚拟主机、日志、认证及优化
查看>>
常用的两种数据分区方法(以Teradata为例)
查看>>
Nginx Rewrite正则表达式案例
查看>>
一个新兴的日志管理产品
查看>>
WindowsServer2012史记-安装和配置HyperV
查看>>
Delphi开发的IOCP测试Demo以及使用说明。
查看>>
10分钟学会 Python 函数基础知识
查看>>
应届毕业生求职之我见
查看>>
FAQ:configuration manager未找到站点来管理此客户端
查看>>
微博商城开启社会化电商之路
查看>>
通过脚本案例学习shell(三) --- 通过交互式脚本自动创建Apache虚拟主机
查看>>
在大二,我是怎么月收入5000
查看>>
校验顺序和短路
查看>>
Buffer cache和page cache的区别
查看>>
京东家电&格力:跨界合作如何迎来行业效应?
查看>>
K8S集群Ingress https实践
查看>>