zoukankan      html  css  js  c++  java
  • sed 参数分析


    sed: http://www.gnu.org/software/sed/manual/sed.html
    https://blog.csdn.net/l1259863243/article/details/79364094

    sed的选项、命令、替换标记

    sed 样例

    1. var = value 赋值形式中修改变量的值
      sed -i 's/(var)[[:space:]]*(=)[[:space:]]*([a-z_A-Z]*)/12en_US/'
      2,匹配版本号,3位或者4位
      grep "^[0-9]+.[0-9]+.[0-9]+(.[0-9]+)?$"

    sed命令

    • a after 在当前行下面插入文本。
      sed "/1234/aSDW-R${ver}\\" data.json
      在与1234匹配的行的下面插入一行:SDW-R${ver},其中一个反斜杠,需要输入4个

    • i 在当前行上面插入文本。
      sed -i "${insert_position_line}i\ \tVAR = $value" $filename
      这里i后面有三个反斜杠,第一个是与i命令搭配的,后两个才是与t搭配的,如果插入两个TAB,第二个TAB前只需要2个反斜杠

    • c 把选定的行改为新的文本。

    • d 删除,删除选择的行。

    • D 删除模板块的第一行。

    • s 替换指定字符

    • h 拷贝模板块的内容到内存中的缓冲区。

    • H 追加模板块的内容到内存中的缓冲区。

    • g 获得内存缓冲区的内容,并替代当前模板块中的文本。

    • G 获得内存缓冲区的内容,并追加到当前模板块文本的后面。

    • l 列表不能打印字符的清单。

    • n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。

    • N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。

    • p 打印模板块的行。

    • P(大写) 打印模板块的第一行。

    • q 退出Sed。

    • b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。

    • r file 从file中读行。

    • t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。

    • T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。

    • w file 写并追加模板块到file

    • # 把注释扩展到下一个换行符以前。

    sed替换标记

    • g 表示行内全面替换。
    • p 表示打印行。
    • w 表示把行写入一个文件。
    • x 表示互换模板块中的文本和缓冲区中的文本。
    • y 表示把一个字符翻译为另外的字符(但是不用于正则表达式)
    • 1 子串匹配标记
    • & 已匹配字符串标记

    sed元字符集

    • ^ 匹配行开始,如:/^sed/匹配所有以sed开头的行。
    • $ 匹配行结束,如:/sed$/匹配所有以sed结尾的行。
    • . 匹配一个非换行符的任意字符,如:/s.d/匹配s后接一个任意字符,最后是d。
    • * 匹配0个或多个字符,如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。
    • [] 匹配一个指定范围内的字符,如/[ss]ed/匹配sed和Sed。
    • [^] 匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed的行。
    • (..) 匹配子串,保存匹配的字符,如s/(love)able/1rs,loveable被替换成lovers。
    • & 保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。
    • < 匹配单词的开始,如:/<love/匹配包含以love开头的单词的行。
    • > 匹配单词的结束,如/love>/匹配包含以love结尾的单词的行。
    • x{m} 重复字符x,m次,如:/0{5}/匹配包含5个0的行。
    • x{m,} 重复字符x,至少m次,如:/0{5,}/匹配至少有5个0的行。
    • x{m,n} 重复字符x,至少m次,不多于n次,如:/0{5,10}/匹配5~10个0的行。

    sed

    Overview

    • 使用sed的常见形式
      sed SCRIPT INPUTFILE...

    sed替换命令:s

    • 把文件中的‘hello’ 替换为 ‘world’
      sed 's/hello/world/g' input.txt > output.txt
      其中 选项g是指替换所有搭配,不只是第一个。

    sed 删除命令:d

    • 把输入文件中所有匹配的行删除。
      sed -i '/hello/d' input.txt
      sed -i "/$var/d" input.txt

    • 不说明输入文件或是输入文件为横杆时候,sed将处理标准输入的内容,下面命令等价
      sed 's/hello/world/' input.txt > output.txt
      sed 's/hello/world/' < input.txt > output.txt
      cat input.txt | sed 's/hello/world/' - > output.txt

    • sed 默认输出是标准输出,用选项 -i ,把编辑的结果保存到文件,而不是把结果打印到标准输出。
      下面的命令会修改文件,没有输出。
      sed -i 's/hello/world/' file.txt

    • sed 默认打印所有要处理的输入行(除非通过d删除的行不打印),选项 -n to suppress output,用-p打印特定行,
      下面的命令打印第3行
      sed -n '45p' file.txt

    • 没有选项-e or -f 时候,sed用第一个非选项参数作为脚本例如( 's/hello/world/'),接着的非选项参数作为输入文件。
      如果有选项-e or -f 来指定脚本,所有的非选项参数作为输入文件。-e and -f 可以同时出现多次。
      The following examples are equivalent:
      sed 's/hello/world/' input.txt > output.txt
      sed -e 's/hello/world/' input.txt > output.txt
      sed --expression='s/hello/world/' input.txt > output.txt
      echo 's/hello/world/' > myscript.sed
      sed -f myscript.sed input.txt > output.txt
      sed --file=myscript.sed input.txt > output.txt

    命令行选项 Command-Line Options

    • The full format for invoking sed is:
      sed OPTIONS... [SCRIPT] [INPUTFILE...]
  • 相关阅读:
    大数据学习之sqoop框架 25
    大数据学习之Flume框架 24
    大数据学习之Hive UDF及优化23
    大数据学习之HiveDDM数据操作语言22
    大数据学习之Hive数据仓库DDL数据定义语言21
    【MacOs】 SecureCRT设置linux终端显示颜色
    【MacOs】 VMware Fusion的NAT端口映射+静态IP
    【nginx】测试服务器配置内网项目转发
    【Linux】SSH连接linux时,长时间不操作就断开的解决方案
    【PHP】简易系统环境控制
  • 原文地址:https://www.cnblogs.com/ims-/p/14249899.html
Copyright © 2011-2022 走看看