0

我有一个看起来像这样的文件(只是其中的一部分)

    center      cont      flux       eqw      core     gfwhm      fwhm                                                
  7367.332 0.3494628 -0.002165  0.006196 -0.026459   0.07688        0.                                                
  7372.827 0.3524984 -9.457E-4  0.002683 -0.011192   0.07938        0.                                                
  7384.392 0.3463771 -0.001513  0.004369 -0.024297   0.05851        0.                                                
  7384.655 0.3457934 -0.003066  0.008867 -0.037102   0.07763        0.                                                
  7387.274  0.347539 -0.014332   0.04124 -0.136604   0.09856        0.                                                
    center      cont      flux       eqw      core     gfwhm     lfwhm                                                
  7391.392 0.3548613 -0.044781    0.1262 -0.203154    0.2071        0.                                                
  7391.645 0.3539104 -0.008767   0.02477 -0.021864    0.3767        0.                                                
    center      cont      flux       eqw      core     gfwhm     lfwhm                                                
  7400.522 0.3491196 -4.204E-4  0.001204 -0.005909   0.06684        0.                                                
  7405.889  0.348969 -6.845E-4  0.001961 -0.009793   0.06566        0.

我想在包含字符串,等#的每一行的开头添加一个。它们看起来都很相似,所以搜索应该就足够了。centercontcenter

如果另外我可以添加到脚本中,那么什么都不会发生,如果他们的行已经包含一个#很棒的,但在这里不是超级重要的。

输出应如下所示:

   #center      cont      flux       eqw      core     gfwhm      fwhm                                                
  7367.332 0.3494628 -0.002165  0.006196 -0.026459   0.07688        0.                                                
  7372.827 0.3524984 -9.457E-4  0.002683 -0.011192   0.07938        0.                                                
  7384.392 0.3463771 -0.001513  0.004369 -0.024297   0.05851        0.                                                
  7384.655 0.3457934 -0.003066  0.008867 -0.037102   0.07763        0.                                                
  7387.274  0.347539 -0.014332   0.04124 -0.136604   0.09856        0.                                                
   #center      cont      flux       eqw      core     gfwhm     lfwhm                                                
  7391.392 0.3548613 -0.044781    0.1262 -0.203154    0.2071        0.                                                
  7391.645 0.3539104 -0.008767   0.02477 -0.021864    0.3767        0.                                                
   #center      cont      flux       eqw      core     gfwhm     lfwhm                                                
  7400.522 0.3491196 -4.204E-4  0.001204 -0.005909   0.06684        0.                                                
  7405.889  0.348969 -6.845E-4  0.001961 -0.009793   0.06566        0.

我认为sed可以解决这个问题,但如果有人有更好的主意,我想在这里。

4

5 回答 5

3

使用sed,您可以说:

sed -r 's/^(\s+)(center)/\1#\2/g' filename

这将导致:

    #center      cont      flux       eqw      core     gfwhm      fwhm          
  7367.332 0.3494628 -0.002165  0.006196 -0.026459   0.07688        0.           
  7372.827 0.3524984 -9.457E-4  0.002683 -0.011192   0.07938        0.           
  7384.392 0.3463771 -0.001513  0.004369 -0.024297   0.05851        0.           
  7384.655 0.3457934 -0.003066  0.008867 -0.037102   0.07763        0.           
  7387.274  0.347539 -0.014332   0.04124 -0.136604   0.09856        0.           
    #center      cont      flux       eqw      core     gfwhm     lfwhm          
  7391.392 0.3548613 -0.044781    0.1262 -0.203154    0.2071        0.           
  7391.645 0.3539104 -0.008767   0.02477 -0.021864    0.3767        0.           
    #center      cont      flux       eqw      core     gfwhm     lfwhm          
  7400.522 0.3491196 -4.204E-4  0.001204 -0.005909   0.06684        0.           
  7405.889  0.348969 -6.845E-4  0.001961 -0.009793   0.06566        0.
于 2013-11-14T14:04:37.387 回答
2

您可以使用withsed过滤行,然后将行 ( )的开头替换为:center/center/^#

$ sed '/center/s/^/#/' file
#    center      cont      flux       eqw      core     gfwhm      fwhm
  7367.332 0.3494628 -0.002165  0.006196 -0.026459   0.07688        0.
  7372.827 0.3524984 -9.457E-4  0.002683 -0.011192   0.07938        0.
  7384.392 0.3463771 -0.001513  0.004369 -0.024297   0.05851        0.
  7384.655 0.3457934 -0.003066  0.008867 -0.037102   0.07763        0.
  7387.274  0.347539 -0.014332   0.04124 -0.136604   0.09856        0.
#    center      cont      flux       eqw      core     gfwhm     lfwhm
  7391.392 0.3548613 -0.044781    0.1262 -0.203154    0.2071        0.
  7391.645 0.3539104 -0.008767   0.02477 -0.021864    0.3767        0.
#    center      cont      flux       eqw      core     gfwhm     lfwhm
  7400.522 0.3491196 -4.204E-4  0.001204 -0.005909   0.06684        0.
  7405.889  0.348969 -6.845E-4  0.001961 -0.009793   0.06566        0.

如果您需要#恰好在center文本旁边,那么可以这样做:捕获空格,然后在#.

$ sed -r '/center/s/^(\s*)/\1#/' file
    #center      cont      flux       eqw      core     gfwhm      fwhm
  7367.332 0.3494628 -0.002165  0.006196 -0.026459   0.07688        0.
...

如果您没有该-r选项,sed则可以使用等效项:

sed '/center/s/^\(\s*\)/\1#/' file

有了awk它甚至更快:您可以过滤包含center并添加#到第一个字段的行:

$ awk '/center/ {$1="#"$1}1' file
#center cont flux eqw core gfwhm fwhm
  7367.332 0.3494628 -0.002165  0.006196 -0.026459   0.07688        0.
  7372.827 0.3524984 -9.457E-4  0.002683 -0.011192   0.07938        0.
...
于 2013-11-14T14:02:32.650 回答
1

使用 sed 很简单:

 sed -i.bak '/center/s/^\([^#]\)/#\1/' file.txt

发生了什么(来自tutorialspoint.comman sedsed regex):

-i.bak     Edit files in place (makes backup if extension supplied)
/center/   Matches lines that contain the word center.
s/???/???/ Or s/regexp/replacement/, Attempt to match regexp against the pattern space.
/          Field separator to 's'.
^          Match first character on line.
\(         Start back reference.
[^#]       Do not match any charcter (^ = don't) in this list (only # listed).
\)         End back reference.
#          Literal '#'
\1         The first back reference.

同样的事情只是不产生备份文件(file.txt.bak):

 sed -i '/center/s/^\([^#]\)/#\1/' file.txt
于 2013-11-14T14:14:25.027 回答
1

使用awk

awk '{sub(/center/,"#&")}1' file
于 2013-11-14T14:16:02.197 回答
0
sed "/center/ !b;s/^\s*/&#/"

在这种情况下,我们也可以尝试

sed "/[0-9]/ b;s/^\s*/&#/"

假设文本行中没有数字或

sed "/[a-zA-Z]/ s/^\s*/&#/"

假设数据线中没有字母

于 2013-11-14T15:09:17.213 回答