sed简明教程——转载自左耳朵耗子博客coolshell

发布时间 2023-06-13 10:51:12作者: xiao__fei

<h1><a name="t0"></a><a id="sed__0"></a><a class="hl hl-1" href="https://so.csdn.net/so/search?q=sed&amp;spm=1001.2101.3001.7020" target="_blank" rel="noopener" data-report-click="{&quot;spm&quot;:&quot;1001.2101.3001.7020&quot;,&quot;dest&quot;:&quot;https://so.csdn.net/so/search?q=sed&amp;spm=1001.2101.3001.7020&quot;,&quot;extra&quot;:&quot;{\&quot;searchword\&quot;:\&quot;sed\&quot;}&quot;}" data-tit="sed" data-pretit="sed">sed</a> 简明教程</h1>
<blockquote>
<p>转自:https://coolshell.cn/articles/9104.html</p>
</blockquote>
<div class="entry-content">
<p><script async="" src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-3415450859608158" crossorigin="anonymous" type="text/javascript"></script><img decoding="async" class="alignright wp-image-9126" src="https://coolshell.cn/wp-content/uploads/2013/02/sed-superman.png" alt="" width="216" height="216" srcset="https://coolshell.cn/wp-content/uploads/2013/02/sed-superman.png 270w, https://coolshell.cn/wp-content/uploads/2013/02/sed-superman-150x150.png 150w, https://coolshell.cn/wp-content/uploads/2013/02/sed-superman-200x200.png 200w" sizes="(max-width: 216px) 100vw, 216px">awk于1977年出生,今年36岁本命年,sed比awk大2-3岁,awk就像林妹妹,sed就是宝玉哥哥了。所以&nbsp;<a title="AWK 简明教程" href="https://coolshell.cn/articles/9070.html" target="_blank" rel="noopener noreferrer">林妹妹跳了个Topless</a>,他的哥哥sed坐不住了,也一定要出来抖一抖。</p>
<p>sed全名叫stream editor,流编辑器,用程序的方式来编辑文本,相当的hacker啊。sed基本上就是玩正则模式匹配,所以,玩sed的人,正则表达式一般都比较强。</p>
<p>同样,本篇文章不会说sed的全部东西,你可以参看<a href="http://www.gnu.org/software/sed/manual/sed.html" target="_blank" rel="noopener noreferrer">sed的手册</a>,我这里主要还是想和大家竞争一下那些从手机指缝间或马桶里流走的时间,用这些时间来学习一些东西。当然,接下来的还是要靠大家自己双手。</p>
<div id="ez-toc-container" class="ez-toc-v2_0_48 counter-hierarchy ez-toc-counter ez-toc-grey ez-toc-container-direction">
<div class="ez-toc-title-container">
<p class="ez-toc-title">目录</p>
<span class="ez-toc-title-toggle"></span></div>
<nav><ul class="ez-toc-list ez-toc-list-level-1 "><li class="ez-toc-page-1 ez-toc-heading-level-4"><a class="ez-toc-link ez-toc-heading-1" href="#%E7%94%A8s%E5%91%BD%E4%BB%A4%E6%9B%BF%E6%8D%A2" title="用s命令替换">用s命令替换</a></li><li class="ez-toc-page-1 ez-toc-heading-level-4"><a class="ez-toc-link ez-toc-heading-2" href="#%E5%A4%9A%E4%B8%AA%E5%8C%B9%E9%85%8D" title="多个匹配">多个匹配</a></li><li class="ez-toc-page-1 ez-toc-heading-level-4"><a class="ez-toc-link ez-toc-heading-3" href="#%E5%9C%86%E6%8B%AC%E5%8F%B7%E5%8C%B9%E9%85%8D" title="圆括号匹配">圆括号匹配</a></li><li class="ez-toc-page-1 ez-toc-heading-level-4"><a class="ez-toc-link ez-toc-heading-4" href="#sed%E7%9A%84%E5%91%BD%E4%BB%A4" title="sed的命令">sed的命令</a><ul class="ez-toc-list-level-5"><li class="ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-5" href="#N%E5%91%BD%E4%BB%A4" title="N命令">N命令</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-6" href="#a%E5%91%BD%E4%BB%A4%E5%92%8Ci%E5%91%BD%E4%BB%A4" title="a命令和i命令">a命令和i命令</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-7" href="#c%E5%91%BD%E4%BB%A4" title="c命令">c命令</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-8" href="#d%E5%91%BD%E4%BB%A4" title="d命令">d命令</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-9" href="#p%E5%91%BD%E4%BB%A4" title="p命令">p命令</a></li></ul></li><li class="ez-toc-page-1 ez-toc-heading-level-4"><a class="ez-toc-link ez-toc-heading-10" href="#%E5%87%A0%E4%B8%AA%E7%9F%A5%E8%AF%86%E7%82%B9" title="几个知识点">几个知识点</a><ul class="ez-toc-list-level-5"><li class="ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-11" href="#Pattern_Space" title="Pattern Space">Pattern Space</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-12" href="#Address" title="Address">Address</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-13" href="#%E5%91%BD%E4%BB%A4%E6%89%93%E5%8C%85" title="命令打包">命令打包</a></li><li class="ez-toc-page-1 ez-toc-heading-level-5"><a class="ez-toc-link ez-toc-heading-14" href="#Hold_Space" title="Hold Space">Hold Space</a></li></ul></li></ul></nav></div>
<h4><span class="ez-toc-section" id="%E7%94%A8s%E5%91%BD%E4%BB%A4%E6%9B%BF%E6%8D%A2" ez-toc-data-id="#用s命令替换"></span>用s命令替换<span class="ez-toc-section-end"></span></h4>
<p>我使用下面的这段文本做演示:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ cat pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ cat pets.txt
This is my cat
  my cat's name is betty
This is my dog
  my dog's name is frank
This is my fish
  my fish's name is george
This is my goat
  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ cat pets.txt
This is my cat
  my cat's name is betty
This is my dog
  my dog's name is frank
This is my fish
  my fish's name is george
This is my goat
  my goat's name is adam</pre>
<p>把其中的my字符串替换成Hao Chen’s,下面的语句应该很好理解(s表示替换命令,/my/表示匹配my,/Hao Chen’s/表示把匹配替换成Hao Chen’s,/g 表示一行上的替换所有的匹配):</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"s/my/Hao Chen's/g"</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is Hao Chen</span><span class="enlighter-s0">'s cat</span></div></div><div class=""><div><span class="enlighter-s0">  Hao Chen'</span><span class="enlighter-text">s cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is Hao Chen'</span><span class="enlighter-text">s dog</span></div></div><div class=""><div><span class="enlighter-text">  Hao Chen</span><span class="enlighter-s0">'s dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is Hao Chen</span><span class="enlighter-s0">'s fish</span></div></div><div class=""><div><span class="enlighter-s0">  Hao Chen'</span><span class="enlighter-text">s fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is Hao Chen'</span><span class="enlighter-text">s goat</span></div></div><div class=""><div><span class="enlighter-text">  Hao Chen</span><span class="enlighter-s0">'s goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed "s/my/Hao Chen's/g" pets.txt
This is Hao Chen's cat
  Hao Chen's cat's name is betty
This is Hao Chen's dog
  Hao Chen's dog's name is frank
This is Hao Chen's fish
  Hao Chen's fish's name is george
This is Hao Chen's goat
  Hao Chen's goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed "s/my/Hao Chen's/g" pets.txt
This is Hao Chen's cat
  Hao Chen's cat's name is betty
This is Hao Chen's dog
  Hao Chen's dog's name is frank
This is Hao Chen's fish
  Hao Chen's fish's name is george
This is Hao Chen's goat
  Hao Chen's goat's name is adam</pre>
<p>注意:如果你要使用单引号,那么你没办法通过\’这样来转义,就有双引号就可以了,在双引号内可以用\”来转义。</p>
<p><span id="more-9104"></span></p>
<p>再注意:上面的sed并没有对文件的内容改变,只是把处理过后的内容输出,如果你要写回文件,你可以使用重定向,如:</p>
<p><div class="enlighter-default enlighter-v-inline enlighter-t-wpcustom enlighter-l-shell "><span class="enlighter"><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"s/my/Hao Chen's/g"</span><span class="enlighter-text"> pets.txt &gt; hao_pets.txt</span></span></div><code data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed "s/my/Hao Chen's/g" pets.txt &gt; hao_pets.txt</code></p>
<p>或使用 -i 参数直接修改文件内容:</p>
<p><div class="enlighter-default enlighter-v-inline enlighter-t-wpcustom enlighter-l-shell "><span class="enlighter"><span class="enlighter-text">$ sed -i </span><span class="enlighter-s0">"s/my/Hao Chen's/g"</span><span class="enlighter-text"> pets.txt</span></span></div><code data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed -i "s/my/Hao Chen's/g" pets.txt</code></p>
<p>在每一行最前面加点东西:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/^/#/g'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#This is my cat</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#  my cat's name is betty</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#This is my dog</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#  my dog's name is frank</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#This is my fish</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#  my fish's name is george</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#This is my goat</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#  my goat's name is adam</span></div></div></div><div class="enlighter-raw">$ sed 's/^/#/g' pets.txt
#This is my cat
#  my cat's name is betty
#This is my dog
#  my dog's name is frank
#This is my fish
#  my fish's name is george
#This is my goat
#  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/^/#/g' pets.txt
#This is my cat
#  my cat's name is betty
#This is my dog
#  my dog's name is frank
#This is my fish
#  my fish's name is george
#This is my goat
#  my goat's name is adam</pre>
<p>在每一行最后面加点东西:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/$/ --- /g'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat ---</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty ---</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog ---</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank ---</span></div></div><div class=""><div><span class="enlighter-text">This is my fish ---</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george ---</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat ---</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam ---</span></div></div></div><div class="enlighter-raw">$ sed 's/$/ --- /g' pets.txt
This is my cat ---
  my cat's name is betty ---
This is my dog ---
  my dog's name is frank ---
This is my fish ---
  my fish's name is george ---
This is my goat ---
  my goat's name is adam ---</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/$/ --- /g' pets.txt
This is my cat ---
  my cat's name is betty ---
This is my dog ---
  my dog's name is frank ---
This is my fish ---
  my fish's name is george ---
This is my goat ---
  my goat's name is adam ---</pre>
<p>顺手介绍一下正则表达式的一些最基本的东西:</p>
<ul>
<li> <code>^</code> 表示一行的开头。如:<code>/^#/</code> 以#开头的匹配。</li>
<li> <code>$</code> 表示一行的结尾。如:<code>/}$/</code> 以}结尾的匹配。</li>
<li> <code>\&lt;</code> 表示词首。 如:<code>\&lt;abc</code> 表示以 abc 为首的詞。</li>
<li> <code>\&gt;</code> 表示词尾。 如:<code>abc\&gt;</code> 表示以 abc 結尾的詞。</li>
<li> <code>.</code> 表示任何单个字符。</li>
<li> <code>*</code> 表示某个字符出现了0次或多次。</li>
<li> <code>[ ]</code> 字符集合。 如:<code>[abc]</code> 表示匹配a或b或c,还有 <code>[a-zA-Z]</code> 表示匹配所有的26个字符。如果其中有^表示反,如 <code>[^a]</code> 表示非a的字符</li>
</ul>
<p>正规则表达式是一些很牛的事,比如我们要去掉某html中的tags:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-xml enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-g1">&lt;</span><span class="enlighter-x1">b</span><span class="enlighter-g1">&gt;</span><span class="enlighter-text">This</span><span class="enlighter-g1">&lt;/</span><span class="enlighter-x1">b</span><span class="enlighter-g1">&gt;</span><span class="enlighter-text"> is what </span><span class="enlighter-g1">&lt;</span><span class="enlighter-x1">span</span><span class="enlighter-text"> </span><span class="enlighter-x2">style</span><span class="enlighter-k3">=</span><span class="enlighter-s0">"text-decoration: underline;"</span><span class="enlighter-g1">&gt;</span><span class="enlighter-text">I</span><span class="enlighter-g1">&lt;/</span><span class="enlighter-x1">span</span><span class="enlighter-g1">&gt;</span><span class="enlighter-text"> meant. Understand?</span></div></div></div><div class="enlighter-raw">&lt;b&gt;This&lt;/b&gt; is what &lt;span style="text-decoration: underline;"&gt;I&lt;/span&gt; meant. Understand?</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="html" class="EnlighterJSRAW enlighter-origin">
&lt;b&gt;This&lt;/b&gt; is what &lt;span style="text-decoration: underline;"&gt;I&lt;/span&gt; meant. Understand?

</pre>
<p>看看我们的sed命令</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-c0"># 如果你这样搞的话,就会有问题</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/&lt;.*&gt;//g'</span><span class="enlighter-text"> html.txt</span></div></div><div class=""><div><span class="enlighter-text"> Understand?</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 要解决上面的那个问题,就得像下面这样。</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 其中的'[^&gt;]' 指定了除了&gt;的字符重复0次或多次。</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/&lt;[^&gt;]*&gt;//g'</span><span class="enlighter-text"> html.txt</span></div></div><div class=""><div><span class="enlighter-text">This is what I meant. Understand?</span></div></div></div><div class="enlighter-raw"># 如果你这样搞的话,就会有问题
$ sed 's/&lt;.*&gt;//g' html.txt
 Understand?

# 要解决上面的那个问题,就得像下面这样。
# 其中的'[^&gt;]' 指定了除了&gt;的字符重复0次或多次。
$ sed 's/&lt;[^&gt;]*&gt;//g' html.txt
This is what I meant. Understand?</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin"># 如果你这样搞的话,就会有问题
$ sed 's/&lt;.*&gt;//g' html.txt
 Understand?

# 要解决上面的那个问题,就得像下面这样。
# 其中的'[^&gt;]' 指定了除了&gt;的字符重复0次或多次。
$ sed 's/&lt;[^&gt;]*&gt;//g' html.txt
This is what I meant. Understand?</pre>
<p>我们再来看看指定需要替换的内容:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"3s/my/your/g"</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class="enlighter-special"><div><span class="enlighter-s0">This is your dog</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed "3s/my/your/g" pets.txt
This is my cat
  my cat's name is betty
This is your dog
  my dog's name is frank
This is my fish
  my fish's name is george
This is my goat
  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="4">$ sed "3s/my/your/g" pets.txt
This is my cat
  my cat's name is betty
This is your dog
  my dog's name is frank
This is my fish
  my fish's name is george
This is my goat
  my goat's name is adam</pre>
<p>下面的命令只替换第3到第6行的文本。</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"3,6s/my/your/g"</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class="enlighter-special"><div><span class="enlighter-s0">This is your dog</span></div></div><div class="enlighter-special"><div><span class="enlighter-s0">  your dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class="enlighter-special"><div><span class="enlighter-text">This is your fish</span></div></div><div class="enlighter-special"><div><span class="enlighter-text">  your fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed "3,6s/my/your/g" pets.txt
This is my cat
  my cat's name is betty
This is your dog
  your dog's name is frank
This is your fish
  your fish's name is george
This is my goat
  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="4,5,6,7">$ sed "3,6s/my/your/g" pets.txt
This is my cat
  my cat's name is betty
This is your dog
  your dog's name is frank
This is your fish
  your fish's name is george
This is my goat
  my goat's name is adam</pre>
<p>&nbsp;</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ cat my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ cat my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ cat my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my goat, my goat's name is adam</pre>
<p>只替换每一行的第一个s:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/s/S/1'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">ThiS is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">ThiS is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">ThiS is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">ThiS is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed 's/s/S/1' my.txt
ThiS is my cat, my cat's name is betty
ThiS is my dog, my dog's name is frank
ThiS is my fish, my fish's name is george
ThiS is my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/s/S/1' my.txt
ThiS is my cat, my cat's name is betty
ThiS is my dog, my dog's name is frank
ThiS is my fish, my fish's name is george
ThiS is my goat, my goat's name is adam</pre>
<p>只替换每一行的第二个s:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/s/S/2'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This iS my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This iS my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This iS my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This iS my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed 's/s/S/2' my.txt
This iS my cat, my cat's name is betty
This iS my dog, my dog's name is frank
This iS my fish, my fish's name is george
This iS my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/s/S/2' my.txt
This iS my cat, my cat's name is betty
This iS my dog, my dog's name is frank
This iS my fish, my fish's name is george
This iS my goat, my goat's name is adam</pre>
<p>只替换第一行的第3个以后的s:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/s/S/3g'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'S name iS betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">S name iS frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fiSh, my fiSh</span><span class="enlighter-s0">'S name iS george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat, my goat'</span><span class="enlighter-text">S name iS adam</span></div></div></div><div class="enlighter-raw">$ sed 's/s/S/3g' my.txt
This is my cat, my cat'S name iS betty
This is my dog, my dog'S name iS frank
This is my fiSh, my fiSh'S name iS george
This is my goat, my goat'S name iS adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/s/S/3g' my.txt
This is my cat, my cat'S name iS betty
This is my dog, my dog'S name iS frank
This is my fiSh, my fiSh'S name iS george
This is my goat, my goat'S name iS adam</pre>
<h4><span class="ez-toc-section" id="%E5%A4%9A%E4%B8%AA%E5%8C%B9%E9%85%8D" ez-toc-data-id="#多个匹配"></span>多个匹配<span class="ez-toc-section-end"></span></h4>
<p>如果我们需要一次替换多个模式,可参看下面的示例:(第一个模式把第一行到第三行的my替换成your,第二个则把第3行以后的This替换成了That)</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'1,3s/my/your/g; 3,$s/This/That/g'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is your cat, your cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is your dog, your dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">That is your fish, your fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">That is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed '1,3s/my/your/g; 3,$s/This/That/g' my.txt
This is your cat, your cat's name is betty
This is your dog, your dog's name is frank
That is your fish, your fish's name is george
That is my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed '1,3s/my/your/g; 3,$s/This/That/g' my.txt
This is your cat, your cat's name is betty
This is your dog, your dog's name is frank
That is your fish, your fish's name is george
That is my goat, my goat's name is adam</pre>
<p>上面的命令等价于:(注:下面使用的是sed的-e命令行参数)</p>
<p><div class="enlighter-default enlighter-v-inline enlighter-t-wpcustom enlighter-l-shell "><span class="enlighter"><span class="enlighter-text">sed -e </span><span class="enlighter-s0">'1,3s/my/your/g'</span><span class="enlighter-text"> -e </span><span class="enlighter-s0">'3,$s/This/That/g'</span><span class="enlighter-text"> my.txt</span></span></div><code data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">sed -e '1,3s/my/your/g' -e '3,$s/This/That/g' my.txt</code></p>
<p>我们可以使用&amp;来当做被匹配的变量,然后可以在基本左右加点东西。如下所示:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/my/[&amp;]/g'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is [my] cat, [my] cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is [my] dog, [my] dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is [my] fish, [my] fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is [my] goat, [my] goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed 's/my/[&amp;]/g' my.txt
This is [my] cat, [my] cat's name is betty
This is [my] dog, [my] dog's name is frank
This is [my] fish, [my] fish's name is george
This is [my] goat, [my] goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/my/[&amp;]/g' my.txt
This is [my] cat, [my] cat's name is betty
This is [my] dog, [my] dog's name is frank
This is [my] fish, [my] fish's name is george
This is [my] goat, [my] goat's name is adam</pre>
<h4><span class="ez-toc-section" id="%E5%9C%86%E6%8B%AC%E5%8F%B7%E5%8C%B9%E9%85%8D" ez-toc-data-id="#圆括号匹配"></span>圆括号匹配<span class="ez-toc-section-end"></span></h4>
<p>使用圆括号匹配的示例:(圆括号括起来的正则表达式所匹配的字符串会可以当成变量来使用,sed中使用的是\1,\2…)</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'s/This is my \([^,&amp;]*\),.*is \(.*\)/\1:\2/g'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">cat:betty</span></div></div><div class=""><div><span class="enlighter-text">dog:frank</span></div></div><div class=""><div><span class="enlighter-text">fish:george</span></div></div><div class=""><div><span class="enlighter-text">goat:adam</span></div></div></div><div class="enlighter-raw">$ sed 's/This is my \([^,&amp;]*\),.*is \(.*\)/\1:\2/g' my.txt
cat:betty
dog:frank
fish:george
goat:adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 's/This is my \([^,&amp;]*\),.*is \(.*\)/\1:\2/g' my.txt
cat:betty
dog:frank
fish:george
goat:adam</pre>
<p>上面这个例子中的正则表达式有点复杂,解开如下(去掉转义字符):</p>
<p>正则为:This is my ([^,]*),.*is (.*)<br>
匹配为:This is my (cat),……….is (betty)</p>
<p>然后:\1就是cat,\2就是betty</p>
<h4><span class="ez-toc-section" id="sed%E7%9A%84%E5%91%BD%E4%BB%A4" ez-toc-data-id="#sed的命令"></span>sed的命令<span class="ez-toc-section-end"></span></h4>
<p>让我们回到最一开始的例子pets.txt,让我们来看几个命令:</p>
<h5><span class="ez-toc-section" id="N%E5%91%BD%E4%BB%A4" ez-toc-data-id="#N命令"></span>N命令<span class="ez-toc-section-end"></span></h5>
<p>先来看N命令 —— 把下一行的内容纳入当成缓冲区做匹配。</p>
<p>下面的的示例会把原文本中的偶数行纳入奇数行匹配,而s只匹配并替换一次,所以,就成了下面的结果:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'N;s/my/your/'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is your cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is your dog</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is your fish</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is your goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed 'N;s/my/your/' pets.txt
This is your cat
  my cat's name is betty
This is your dog
  my dog's name is frank
This is your fish
  my fish's name is george
This is your goat
  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 'N;s/my/your/' pets.txt
This is your cat
  my cat's name is betty
This is your dog
  my dog's name is frank
This is your fish
  my fish's name is george
This is your goat
  my goat's name is adam</pre>
<p>也就是说,原来的文件成了:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">This is my cat\n  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog\n  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish\n  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat\n  my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">This is my cat\n  my cat's name is betty
This is my dog\n  my dog's name is frank
This is my fish\n  my fish's name is george
This is my goat\n  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">This is my cat\n  my cat's name is betty
This is my dog\n  my dog's name is frank
This is my fish\n  my fish's name is george
This is my goat\n  my goat's name is adam</pre>
<p>这样一来,下面的例子你就明白了,</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'N;s/\n/,/'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat,  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog,  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish,  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat,  my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed 'N;s/\n/,/' pets.txt
This is my cat,  my cat's name is betty
This is my dog,  my dog's name is frank
This is my fish,  my fish's name is george
This is my goat,  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed 'N;s/\n/,/' pets.txt
This is my cat,  my cat's name is betty
This is my dog,  my dog's name is frank
This is my fish,  my fish's name is george
This is my goat,  my goat's name is adam</pre>
<h5><span class="ez-toc-section" id="a%E5%91%BD%E4%BB%A4%E5%92%8Ci%E5%91%BD%E4%BB%A4" ez-toc-data-id="#a命令和i命令"></span>a命令和i命令<span class="ez-toc-section-end"></span></h5>
<p>a命令就是append, i命令就是insert,它们是用来添加行的。如:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-c0"># 其中的1i表明,其要在第1行前插入一行(insert)</span><span class="enlighter-text"></span></div></div><div class="enlighter-special"><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"1 i This is my monkey, my monkey's name is wukong"</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my monkey, my monkey</span><span class="enlighter-s0">'s name is wukong</span></div></div><div class=""><div><span class="enlighter-s0">This is my cat, my cat'</span><span class="enlighter-text">s name is betty</span></div></div><div class=""><div><span class="enlighter-text">This is my dog, my dog</span><span class="enlighter-s0">'s name is frank</span></div></div><div class=""><div><span class="enlighter-s0">This is my fish, my fish'</span><span class="enlighter-text">s name is george</span></div></div><div class=""><div><span class="enlighter-text">This is my goat, my goat</span><span class="enlighter-s0">'s name is adam</span></div></div><div class=""><div><span class="enlighter-s0"></span></div></div><div class=""><div><span class="enlighter-s0"># 其中的1a表明,其要在最后一行后追加一行(append)</span></div></div><div class=""><div><span class="enlighter-s0">$ sed "$ a This is my monkey, my monkey'</span><span class="enlighter-text">s name is wukong" my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class="enlighter-special"><div><span class="enlighter-s0">This is my monkey, my monkey'</span><span class="enlighter-text">s name is wukong</span></div></div><div class=""><div><span class="enlighter-text">This is my dog, my dog</span><span class="enlighter-s0">'s name is frank</span></div></div><div class=""><div><span class="enlighter-s0">This is my fish, my fish'</span><span class="enlighter-text">s name is george</span></div></div><div class=""><div><span class="enlighter-text">This is my goat, my goat's name is adam</span></div></div></div><div class="enlighter-raw"># 其中的1i表明,其要在第1行前插入一行(insert)
$ sed "1 i This is my monkey, my monkey's name is wukong" my.txt
This is my monkey, my monkey's name is wukong
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

# 其中的1a表明,其要在最后一行后追加一行(append)
$ sed "$ a This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my monkey, my monkey's name is wukong
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="2,12"># 其中的1i表明,其要在第1行前插入一行(insert)
$ sed "1 i This is my monkey, my monkey's name is wukong" my.txt
This is my monkey, my monkey's name is wukong
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

# 其中的1a表明,其要在最后一行后追加一行(append)
$ sed "$ a This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my monkey, my monkey's name is wukong
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my goat, my goat's name is adam</pre>
<p>我们可以运用匹配来添加文本:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-c0"># 注意其中的/fish/a,这意思是匹配到/fish/后就追加一行</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"/fish/a This is my monkey, my monkey's name is wukong"</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class="enlighter-special"><div><span class="enlighter-s0">This is my monkey, my monkey'</span><span class="enlighter-text">s name is wukong</span></div></div><div class=""><div><span class="enlighter-text">This is my goat, my goat's name is adam</span></div></div></div><div class="enlighter-raw"># 注意其中的/fish/a,这意思是匹配到/fish/后就追加一行
$ sed "/fish/a This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my monkey, my monkey's name is wukong
This is my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="6"># 注意其中的/fish/a,这意思是匹配到/fish/后就追加一行
$ sed "/fish/a This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my monkey, my monkey's name is wukong
This is my goat, my goat's name is adam</pre>
<p>下面这个例子是对每一行都挺插入:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"/my/a ----"</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">----</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">----</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">----</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div><div class=""><div><span class="enlighter-text">----</span></div></div></div><div class="enlighter-raw">$ sed "/my/a ----" my.txt
This is my cat, my cat's name is betty
----
This is my dog, my dog's name is frank
----
This is my fish, my fish's name is george
----
This is my goat, my goat's name is adam
----</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed "/my/a ----" my.txt
This is my cat, my cat's name is betty
----
This is my dog, my dog's name is frank
----
This is my fish, my fish's name is george
----
This is my goat, my goat's name is adam
----</pre>
<h5><span class="ez-toc-section" id="c%E5%91%BD%E4%BB%A4" ez-toc-data-id="#c命令"></span>c命令<span class="ez-toc-section-end"></span></h5>
<p>c 命令是替换匹配行</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"2 c This is my monkey, my monkey's name is wukong"</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my monkey, my monkey'</span><span class="enlighter-text">s name is wukong</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">"/fish/c This is my monkey, my monkey's name is wukong"</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my monkey, my monkey</span><span class="enlighter-s0">'s name is wukong</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div></div><div class="enlighter-raw">$ sed "2 c This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my monkey, my monkey's name is wukong
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

$ sed "/fish/c This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my monkey, my monkey's name is wukong
This is my goat, my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed "2 c This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my monkey, my monkey's name is wukong
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

$ sed "/fish/c This is my monkey, my monkey's name is wukong" my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my monkey, my monkey's name is wukong
This is my goat, my goat's name is adam</pre>
<h5><span class="ez-toc-section" id="d%E5%91%BD%E4%BB%A4" ez-toc-data-id="#d命令"></span>d命令<span class="ez-toc-section-end"></span></h5>
<p>删除匹配行</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'/fish/d'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my goat, my goat</span><span class="enlighter-s0">'s name is adam</span></div></div><div class=""><div><span class="enlighter-s0"></span></div></div><div class=""><div><span class="enlighter-s0">$ sed '</span><span class="enlighter-text">2d</span><span class="enlighter-s0">' my.txt</span></div></div><div class=""><div><span class="enlighter-s0">This is my cat, my cat'</span><span class="enlighter-text">s name is betty</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat, my goat'</span><span class="enlighter-text">s name is adam</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'2,$d'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat's name is betty</span></div></div></div><div class="enlighter-raw">$ sed '/fish/d' my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my goat, my goat's name is adam

$ sed '2d' my.txt
This is my cat, my cat's name is betty
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

$ sed '2,$d' my.txt
This is my cat, my cat's name is betty</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ sed '/fish/d' my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my goat, my goat's name is adam

$ sed '2d' my.txt
This is my cat, my cat's name is betty
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

$ sed '2,$d' my.txt
This is my cat, my cat's name is betty</pre>
<h5><span class="ez-toc-section" id="p%E5%91%BD%E4%BB%A4" ez-toc-data-id="#p命令"></span>p命令<span class="ez-toc-section-end"></span></h5>
<p>打印命令</p>
<p>你可以把这个命令当成grep式的命令</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-c0"># 匹配fish并输出,可以看到fish的那一行被打了两遍,</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 这是因为sed处理时会把处理的信息输出</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'/fish/p'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my fish, my fish'</span><span class="enlighter-text">s name is george</span></div></div><div class=""><div><span class="enlighter-text">This is my goat, my goat</span><span class="enlighter-s0">'s name is adam</span></div></div><div class=""><div><span class="enlighter-s0"></span></div></div><div class=""><div><span class="enlighter-s0"># 使用n参数就好了</span></div></div><div class=""><div><span class="enlighter-s0">$ sed -n '</span><span class="enlighter-text">/fish/p</span><span class="enlighter-s0">' my.txt</span></div></div><div class=""><div><span class="enlighter-s0">This is my fish, my fish'</span><span class="enlighter-text">s name is george</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 从一个模式到另一个模式</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed -n </span><span class="enlighter-s0">'/dog/,/fish/p'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my dog, my dog</span><span class="enlighter-s0">'s name is frank</span></div></div><div class=""><div><span class="enlighter-s0">This is my fish, my fish'</span><span class="enlighter-text">s name is george</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#从第一行打印到匹配fish成功的那一行</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed -n </span><span class="enlighter-s0">'1,/fish/p'</span><span class="enlighter-text"> my.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat, my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog, my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish, my fish's name is george</span></div></div></div><div class="enlighter-raw"># 匹配fish并输出,可以看到fish的那一行被打了两遍,
# 这是因为sed处理时会把处理的信息输出
$ sed '/fish/p' my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

# 使用n参数就好了
$ sed -n '/fish/p' my.txt
This is my fish, my fish's name is george

# 从一个模式到另一个模式
$ sed -n '/dog/,/fish/p' my.txt
This is my dog, my dog's name is frank
This is my fish, my fish's name is george

#从第一行打印到匹配fish成功的那一行
$ sed -n '1,/fish/p' my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin"># 匹配fish并输出,可以看到fish的那一行被打了两遍,
# 这是因为sed处理时会把处理的信息输出
$ sed '/fish/p' my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george
This is my fish, my fish's name is george
This is my goat, my goat's name is adam

# 使用n参数就好了
$ sed -n '/fish/p' my.txt
This is my fish, my fish's name is george

# 从一个模式到另一个模式
$ sed -n '/dog/,/fish/p' my.txt
This is my dog, my dog's name is frank
This is my fish, my fish's name is george

#从第一行打印到匹配fish成功的那一行
$ sed -n '1,/fish/p' my.txt
This is my cat, my cat's name is betty
This is my dog, my dog's name is frank
This is my fish, my fish's name is george</pre>
<h4><span class="ez-toc-section" id="%E5%87%A0%E4%B8%AA%E7%9F%A5%E8%AF%86%E7%82%B9" ez-toc-data-id="#几个知识点"></span>几个知识点<span class="ez-toc-section-end"></span></h4>
<p>好了,下面我们要介绍四个sed的基本知识点:</p>
<h5><span class="ez-toc-section" id="Pattern_Space" ez-toc-data-id="#Pattern_Space"></span>Pattern Space<span class="ez-toc-section-end"></span></h5>
<p>第零个是关于-n参数的,大家也许没看懂,没关系,我们来看一下sed处理文本的伪代码,并了解一下Pattern Space的概念:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-cpp enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">foreach line in file </span><span class="enlighter-g1">{</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-c0">//放入把行Pattern_Space</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    Pattern_Space </span><span class="enlighter-g1">&lt;</span><span class="enlighter-text">= line;</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-c0">// 对每个pattern space执行sed命令</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    Pattern_Space </span><span class="enlighter-g1">&lt;</span><span class="enlighter-text">= </span><span class="enlighter-m0">EXEC</span><span class="enlighter-g1">(</span><span class="enlighter-text">sed_cmd, Pattern_Space</span><span class="enlighter-g1">)</span><span class="enlighter-text">;</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-c0">// 如果没有指定 -n 则输出处理后的Pattern_Space</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-k1">if</span><span class="enlighter-text"> </span><span class="enlighter-g1">(</span><span class="enlighter-text">sed option hasn't </span><span class="enlighter-s0">"-n"</span><span class="enlighter-g1">)</span><span class="enlighter-text">  </span><span class="enlighter-g1">{</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">       print Pattern_Space</span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-g1">}</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-g1">}</span></div></div></div><div class="enlighter-raw">foreach line in file {
    //放入把行Pattern_Space
    Pattern_Space &lt;= line;

    // 对每个pattern space执行sed命令
    Pattern_Space &lt;= EXEC(sed_cmd, Pattern_Space);

    // 如果没有指定 -n 则输出处理后的Pattern_Space
    if (sed option hasn't "-n")  {
       print Pattern_Space
    }
}</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="c" class="EnlighterJSRAW enlighter-origin">foreach line in file {
    //放入把行Pattern_Space
    Pattern_Space &lt;= line;

    // 对每个pattern space执行sed命令
    Pattern_Space &lt;= EXEC(sed_cmd, Pattern_Space);

    // 如果没有指定 -n 则输出处理后的Pattern_Space
    if (sed option hasn't "-n")  {
       print Pattern_Space
    }
}</pre>
<h5><span class="ez-toc-section" id="Address" ez-toc-data-id="#Address"></span>Address<span class="ez-toc-section-end"></span></h5>
<p>第一个是关于address,几乎上述所有的命令都是这样的(注:其中的!表示匹配成功后是否执行命令)</p>
<p><strong>[address[,address]][!]{cmd}</strong></p>
<p>address可以是一个数字,也可以是一个模式,你可以通过逗号要分隔两个address 表示两个address的区间,参执行命令cmd,伪代码如下:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-cpp enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-k5">bool</span><span class="enlighter-text"> bexec = </span><span class="enlighter-e0">false</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">foreach line in file </span><span class="enlighter-g1">{</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-k1">if</span><span class="enlighter-text"> </span><span class="enlighter-g1">(</span><span class="enlighter-text"> </span><span class="enlighter-m0">match</span><span class="enlighter-g1">(</span><span class="enlighter-text">address1</span><span class="enlighter-g1">)</span><span class="enlighter-text"> </span><span class="enlighter-g1">){</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">        bexec = </span><span class="enlighter-e0">true</span><span class="enlighter-text">;</span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-g1">}</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-k1">if</span><span class="enlighter-text"> </span><span class="enlighter-g1">(</span><span class="enlighter-text"> bexec == </span><span class="enlighter-e0">true</span><span class="enlighter-g1">)</span><span class="enlighter-text"> </span><span class="enlighter-g1">{</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">        </span><span class="enlighter-m0">EXEC</span><span class="enlighter-g1">(</span><span class="enlighter-text">sed_cmd</span><span class="enlighter-g1">)</span><span class="enlighter-text">;</span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-g1">}</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-k1">if</span><span class="enlighter-text"> </span><span class="enlighter-g1">(</span><span class="enlighter-text"> </span><span class="enlighter-m0">match</span><span class="enlighter-text"> </span><span class="enlighter-g1">(</span><span class="enlighter-text">address2</span><span class="enlighter-g1">)</span><span class="enlighter-text"> </span><span class="enlighter-g1">)</span><span class="enlighter-text"> </span><span class="enlighter-g1">{</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">        bexec = </span><span class="enlighter-e0">false</span><span class="enlighter-text">;</span></div></div><div class=""><div><span class="enlighter-text">    </span><span class="enlighter-g1">}</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-g1">}</span></div></div></div><div class="enlighter-raw">bool bexec = false
foreach line in file {
    if ( match(address1) ){
        bexec = true;
    }

    if ( bexec == true) {
        EXEC(sed_cmd);
    }

    if ( match (address2) ) {
        bexec = false;
    }
}</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="c" class="EnlighterJSRAW enlighter-origin">bool bexec = false
foreach line in file {
    if ( match(address1) ){
        bexec = true;
    }

    if ( bexec == true) {
        EXEC(sed_cmd);
    }

    if ( match (address2) ) {
        bexec = false;
    }
}</pre>
<p>关于address可以使用相对位置,如:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-c0"># 其中的+3表示后面连续3行</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'/dog/,+3s/^/# /g'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0"># This is my dog</span></div></div><div class=""><div><span class="enlighter-s0">#   my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># This is my fish</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0">#   my fish's name is george</span><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">This is my goat</span></div></div><div class=""><div><span class="enlighter-text">  my goat's name is adam</span></div></div></div><div class="enlighter-raw"># 其中的+3表示后面连续3行
$ sed '/dog/,+3s/^/# /g' pets.txt
This is my cat
  my cat's name is betty
# This is my dog
#   my dog's name is frank
# This is my fish
#   my fish's name is george
This is my goat
  my goat's name is adam</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin"># 其中的+3表示后面连续3行
$ sed '/dog/,+3s/^/# /g' pets.txt
This is my cat
  my cat's name is betty
# This is my dog
#   my dog's name is frank
# This is my fish
#   my fish's name is george
This is my goat
  my goat's name is adam</pre>
<h5><span class="ez-toc-section" id="%E5%91%BD%E4%BB%A4%E6%89%93%E5%8C%85" ez-toc-data-id="#命令打包"></span>命令打包<span class="ez-toc-section-end"></span></h5>
<p>第二个是cmd可以是多个,它们可以用分号分开,可以用大括号括起来作为嵌套命令。下面是几个例子:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ cat pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">This is my fish</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 对3行到第6行,执行命令/This/d</span><span class="enlighter-text"></span></div></div><div class="enlighter-special"><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'3,6 {/This/d}'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 对3行到第6行,匹配/This/成功后,再匹配/fish/,成功后执行d命令</span><span class="enlighter-text"></span></div></div><div class="enlighter-special"><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'3,6 {/This/{/fish/d}}'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">This is my cat</span></div></div><div class=""><div><span class="enlighter-text">  my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">This is my dog</span></div></div><div class=""><div><span class="enlighter-s0">  my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">  my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">This is my goat</span></div></div><div class=""><div><span class="enlighter-s0">  my goat'</span><span class="enlighter-text">s name is adam</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text"></span><span class="enlighter-c0"># 从第一行到最后一行,如果匹配到This,则删除之;如果前面有空格,则去除空格</span><span class="enlighter-text"></span></div></div><div class="enlighter-special"><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'1,${/This/d;s/^ *//g}'</span><span class="enlighter-text"> pets.txt</span></div></div><div class=""><div><span class="enlighter-text">my cat</span><span class="enlighter-s0">'s name is betty</span></div></div><div class=""><div><span class="enlighter-s0">my dog'</span><span class="enlighter-text">s name is frank</span></div></div><div class=""><div><span class="enlighter-text">my fish</span><span class="enlighter-s0">'s name is george</span></div></div><div class=""><div><span class="enlighter-s0">my goat'</span><span class="enlighter-text">s name is adam </span></div></div></div><div class="enlighter-raw">$ cat pets.txt
This is my cat
  my cat's name is betty
This is my dog
  my dog's name is frank
This is my fish
  my fish's name is george
This is my goat
  my goat's name is adam

# 对3行到第6行,执行命令/This/d
$ sed '3,6 {/This/d}' pets.txt
This is my cat
  my cat's name is betty
  my dog's name is frank
  my fish's name is george
This is my goat
  my goat's name is adam

# 对3行到第6行,匹配/This/成功后,再匹配/fish/,成功后执行d命令
$ sed '3,6 {/This/{/fish/d}}' pets.txt
This is my cat
  my cat's name is betty
This is my dog
  my dog's name is frank
  my fish's name is george
This is my goat
  my goat's name is adam

# 从第一行到最后一行,如果匹配到This,则删除之;如果前面有空格,则去除空格
$ sed '1,${/This/d;s/^ *//g}' pets.txt
my cat's name is betty
my dog's name is frank
my fish's name is george
my goat's name is adam </div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="12,21,31">$ cat pets.txt
This is my cat
  my cat's name is betty
This is my dog
  my dog's name is frank
This is my fish
  my fish's name is george
This is my goat
  my goat's name is adam

# 对3行到第6行,执行命令/This/d
$ sed '3,6 {/This/d}' pets.txt
This is my cat
  my cat's name is betty
  my dog's name is frank
  my fish's name is george
This is my goat
  my goat's name is adam

# 对3行到第6行,匹配/This/成功后,再匹配/fish/,成功后执行d命令
$ sed '3,6 {/This/{/fish/d}}' pets.txt
This is my cat
  my cat's name is betty
This is my dog
  my dog's name is frank
  my fish's name is george
This is my goat
  my goat's name is adam

# 从第一行到最后一行,如果匹配到This,则删除之;如果前面有空格,则去除空格
$ sed '1,${/This/d;s/^ *//g}' pets.txt
my cat's name is betty
my dog's name is frank
my fish's name is george
my goat's name is adam </pre>
<h5><span class="ez-toc-section" id="Hold_Space" ez-toc-data-id="#Hold_Space"></span>Hold Space<span class="ez-toc-section-end"></span></h5>
<p>第三个我们再来看一下 Hold Space</p>
<p>接下来,我们需要了解一下Hold Space的概念,我们先来看四个命令:</p>
<p>g: 将hold space中的内容拷贝到pattern space中,原来pattern space里的内容清除<br>
G: 将hold space中的内容append到pattern space\n后<br>
h: 将pattern space中的内容拷贝到hold space中,原来的hold space里的内容被清除<br>
H: 将pattern space中的内容append到hold space\n后<br>
x: 交换pattern space和hold space的内容</p>
<p>这些命令有什么用?我们来看两个示例吧,用到的示例文件是:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class=""><div><span class="enlighter-text">$ cat t.txt</span></div></div><div class=""><div><span class="enlighter-text">one</span></div></div><div class=""><div><span class="enlighter-text">two</span></div></div><div class=""><div><span class="enlighter-text">three</span></div></div></div><div class="enlighter-raw">$ cat t.txt
one
two
three</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin">$ cat t.txt
one
two
three</pre>
<p>第一个示例:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class="enlighter-special"><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'H;g'</span><span class="enlighter-text"> t.txt</span></div></div><div class=""><div><span class="enlighter-text">one</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">one</span></div></div><div class=""><div><span class="enlighter-text">two</span></div></div><div class=""><div><span class="enlighter-text"></span></div></div><div class=""><div><span class="enlighter-text">one</span></div></div><div class=""><div><span class="enlighter-text">two</span></div></div><div class=""><div><span class="enlighter-text">three</span></div></div></div><div class="enlighter-raw">$ sed 'H;g' t.txt
one

one
two

one
two
three</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="1">$ sed 'H;g' t.txt
one

one
two

one
two
three</pre>
<p>是不是有点没看懂,我作个图你就看懂了。</p>
<p><img decoding="async" loading="lazy" class="aligncenter size-full wp-image-9118" src="https://coolshell.cn/wp-content/uploads/2013/02/sed_demo_00.jpg" alt="" width="592" height="404" srcset="https://coolshell.cn/wp-content/uploads/2013/02/sed_demo_00.jpg 592w, https://coolshell.cn/wp-content/uploads/2013/02/sed_demo_00-300x204.jpg 300w" sizes="(max-width: 592px) 100vw, 592px"></p>
<p>第二个示例,反序了一个文件的行:</p>
<div class="enlighter-default enlighter-v-standard enlighter-t-wpcustom enlighter-l-shell enlighter-hover enlighter-linenumbers enlighter-overflow-scroll "><div class="enlighter-toolbar-top enlighter-toolbar"><div class="enlighter-btn enlighter-btn-raw"><div class="enlighter-tooltip">Plain text</div></div><div class="enlighter-btn enlighter-btn-copy"><div class="enlighter-tooltip">Copy to clipboard</div></div><div class="enlighter-btn enlighter-btn-window"><div class="enlighter-tooltip">Open code in new window</div></div><div class="enlighter-btn enlighter-btn-website"><div class="enlighter-tooltip">EnlighterJS 3 Syntax Highlighter</div></div></div><div class="enlighter-code"><div class="enlighter" style=""><div class="enlighter-special"><div><span class="enlighter-text">$ sed </span><span class="enlighter-s0">'1!G;h;$!d'</span><span class="enlighter-text"> t.txt</span></div></div><div class=""><div><span class="enlighter-text">three</span></div></div><div class=""><div><span class="enlighter-text">two</span></div></div><div class=""><div><span class="enlighter-text">one</span></div></div></div><div class="enlighter-raw">$ sed '1!G;h;$!d' t.txt
three
two
one</div></div><div class="enlighter-toolbar-bottom enlighter-toolbar"></div></div><pre data-enlighter-language="shell" class="EnlighterJSRAW enlighter-origin" data-enlighter-highlight="1">$ sed '1!G;h;$!d' t.txt
three
two
one</pre>
<p>其中的 ‘1!G;h;$!d’ 可拆解为三个命令</p>
<ul>
<li>1!G —— 只有第一行不执行G命令,将hold space中的内容append回到pattern space</li>
<li>h —— 第一行都执行h命令,将pattern space中的内容拷贝到hold space中</li>
<li>$!d —— 除了最后一行不执行d命令,其它行都执行d命令,删除当前行</li>
</ul>
<p>这个执行序列很难理解,做个图如下大家就明白了:</p>
<p><img decoding="async" loading="lazy" class="aligncenter size-full wp-image-9110" src="https://coolshell.cn/wp-content/uploads/2013/02/sed_demo.jpg" alt="" width="623" height="316" srcset="https://coolshell.cn/wp-content/uploads/2013/02/sed_demo.jpg 623w, https://coolshell.cn/wp-content/uploads/2013/02/sed_demo-300x152.jpg 300w" sizes="(max-width: 623px) 100vw, 623px"></p>
<p>就先说这么多吧,希望对大家有用。</p>
<p>(全文完)</p>
</div>