Sed 命令详解

Sed 命令详解
Sed 命令详解

Sed 命令详解

1.sed -n '2'p filename

打印文件的第二行。

2.sed -n '1,3'p filename

打印文件的1到3行

3. sed -n '/Neave/'p filename

打印匹配Neave的行(模糊匹配)

4. sed -n '4,/The/'p filename

在第4行查询模式The

5. sed -n '1,$'p filename

打印整个文件,$表示最后一行。

6. sed -n '/.*ing/'p filename

匹配任意字母,并以ing结尾的单词(点号不能少)

7 sed -n / -e '/music/'= filename

打印匹配行的行号,-e 会打印文件的内容,同时在匹配行的前面标志行号。-n只打印出实际的行号。8.sed -n -e '/music/'p -e '/music/'= filename

打印匹配的行和行号,行号在内容的下面

9.sed '/company/' a\ "Then suddenly it happend" filename

选择含有company的行,将后面的内容"Then suddenly it happend"加入下一行。注意:它并不改变文件,所有操作在缓冲区,如果要保存输出,重定向到一个文件。

10. sed '/company/' i\ "Then suddenly it happend" filename

同9,只是在匹配的行前插入

11.sed '/company/' c\ "Then suddenly it happend" filename

用"Then suddenly it happend"替换匹配company的行的内容。

12.sed '1'd ( '1,3'd '$'d '/Neave/'d) filename

删除第一行(1到3行,最后一行,匹配Neave的行)

13.[ address [,address]] s/ pattern-to-find /replacement-pattern/[g p w n]

s选项通知s e d这是一个替换操作,并查询pattern-to-find,成功后用replacement-pattern替换它。替换选项如下:

g 缺省情况下只替换第一次出现模式,使用g选项替换全局所有出现模式。

p 缺省s e d将所有被替换行写入标准输出,加p选项将使- n选项无效。- n选项不打印输出结果。

w 文件名使用此选项将输出定向到一个文件。(注意只将匹配替换的行写入文件,而不是整个内容) 14.sed s'/nurse/"hello "&/' filename

将'hello '增加到'nurse'的前面。

15. sed '/company/r append.txt' filename

在匹配company的行的下一行开始加入文件append.txt的内容。

16. sed '/company/'q filename

首次匹配company后就退出sed程序

只所以看sed命令,是因为我遇到了这个一个问题。

网上有很多教程,他们发表了很多程序代码,但是作者为了解释方便,都对程序作了行号编码,就像下面这样:

代码::

1:#!/bin/bash

2:#rename file extesions

3:#

4:# rfe old_extensions new_extension

假设这个文件名是tmp,那么我们可以使用下面的命令来去掉这个行号和冒号(:)

代码::

sed -e s'/^[0-9]\{1,\}://g' tmp

不过上面的命令的命令有一个缺点,那就是如果这个行号不是数字开头,而是有空格的话,那就需要修改匹配规则,规则应该修改为匹配第一个非空白字符是数字开始,后面接一个冒号的配对。命令如下:

代码::

sed -e s'/^[^0-9a-zA-Z]*[0-9]\{1,\}://g' tmp

这令我很兴奋,于是想看看sed到底有多厉害,看了以后,明白的是不是sed有多厉害,就像awk一样,他们只是把正规表达式用到了极致。

以 Redhat6.0 为测试环境

事实上在solaris下的sed命令要比linux强,但因为没有测试

环境,我这里只给在linux下经过测试的用法。

★命令行参数简介

★首先假设我们有这样一个文本文件 sedtest.txt

★输出指定范围的行 p

★在每一行前面增加一个制表符(^I)

★在每一行后面增加--end

★显示指定模式匹配行的行号 [/pattern/]=

★在匹配行后面增加文本 [/pattern/]a\ 或者 [address]a\

★删除匹配行 [/pattern/]d 或者 [address1][,address2]d

★替换匹配行 [/pattern/]c\ 或者 [address1][,address2]c\

★在匹配行前面插入文本 [/pattern/]i\ 或者 [address]i\

★替换匹配串(注意不再是匹配行) [addr1][,addr2]s/old/new/g

★限定范围后的模式匹配

★指定替换每一行中匹配的第几次出现

★ &代表最后匹配

★利用sed修改PATH环境变量

★测试并提高sed命令运行效率

★指定输出文件 [address1][,address2]w outputfile

★指定输入文件 [address]r inputfile

★替换相应字符 [address1][,address2]y/old/new/

★ !号的使用

★ \c正则表达式c 的使用

★ sed命令中正则表达式的复杂性

★转换man手册成普通文本格式(新)

★ sed的man手册(用的就是上面的方法)

★命令行参数简介

sed

-e script指定sed编辑命令

-f script file 指定的文件中是sed编辑命令

-n 寂静模式,抑制来自sed命令执行过程中的冗余输出信息,比如只

显示那些被改变的行。

不明白?不要紧,把这些肮脏丢到一边,跟我往下走,不过下面的介绍里

不包括正则表达式的解释,如果你不明白,可能有点麻烦。

★首先假设我们有这样一个文本文件 sedtest.txt

cat > sedtest.txt

Sed is a stream editor

----------------------

A stream editor is used to perform basic text transformations on an input stream --------------------------------------------------------------------------------

While in some ways similar to an editor which permits script ed edits (such as ed )

,

--------------------------------------------------------------------------------

-

-

sed works by making only one pass over the input(s), and is consequently more ----------------------------------------------------------------------------- efficient. But it is sed's ability to filter text in a pipeline which particular

l

y

--------------------------------------------------------------------------------

-

★输出指定范围的行 p other types of editors.

sed -e "1,4p" -n sedtest.txt

sed -e "/from/p" -n sedtest.txt

sed -e "1,/from/p" -n sedtest.txt

★在每一行前面增加一个制表符(^I)

sed "s/^/^I/g" sedtest.txt

注意^I的输入方法是ctrl-v ctrl-i

单个^表示行首

★在每一行后面增加--end

sed "s/$/--end/g" sedtest.txt

单个$表示行尾

★显示指定模式匹配行的行号 [/pattern/]=

sed -e '/is/=' sedtest.txt

1

Sed is a stream editor

----------------------

3

A stream editor is used to perform basic text transformations on an input stream --------------------------------------------------------------------------------

While in some ways similar to an editor which permits script ed edits (such as ed )

,

--------------------------------------------------------------------------------

-

-

7

sed works by making only one pass over the input(s), and is consequently more -----------------------------------------------------------------------------

9

efficient. But it is sed's ability to filter text in a pipeline which particular

l

y

--------------------------------------------------------------------------------

-

-

意思是分析sedtest.txt,显示那些包含is串的匹配行的行号,注意 11行中出现了is字符串这个输出是面向stdout的,如果不做重定向处理,则不影响原来的sedtest.txt

★在匹配行后面增加文本 [/pattern/]a\ 或者 [address]a\

^D

sed -f sedadd.script sedtest.txt

Sed is a stream editor

A stream editor is used to perform basic text transformations on an input stream While in some ways similar to an editor which permits script ed edits (such as ed )

,

--------------------------------------------------------------------------------

-

-

sed works by making only one pass over the input(s), and is consequently more -----------------------------------------------------------------------------

efficient. But it is sed's ability to filter text in a pipeline which particular

l

y

--------------------------------------------------------------------------------

-

-

[scz@ /home/scz/src]> sed -e "a\\

+++++++++

---------------------------------------------

找到包含from字符串的行,在该行的下一行增加+++++++++。

这个输出是面向stdout的,如果不做重定向处理,则不影响原来的sedtest.txt

很多人想在命令行上直接完成这个操作而不是多一个sedadd.script,不幸的是,这需要用?nbsp; ?nbsp;

续行符\,

[scz@ /home/scz/src]> sed -e "/from/a\\

> +++++++++" sedtest.txt

[scz@ /home/scz/src]> sed -e "a\\

> +++++++++" sedtest.txt

上面这条命令将在所有行后增加一个新行+++++++++

[scz@ /home/scz/src]> sed -e "1 a\\

> +++++++++" sedtest.txt

把下面这两行copy/paste到一个shell命令行上,效果一样

+++++++++" sedtest.txt

[address]a\ 只接受一个地址指定

对于a命令,不支持单引号,只能用双引号,而对于d命令等其他命令,同时

★删除匹配行 [/pattern/]d 或者 [address1][,address2]d

sed -e '/---------------------------------------------/d' sedtest.txt

Sed is a stream editor

A stream editor is used to perform basic text transformations on an input stream While in some ways similar to an editor which permits script ed edits (such as ed

)

,

sed works by making only one pass over the input(s), and is consequently more efficient. But it is sed's ability to filter text in a pipeline which particular

l

y

sed -e '6,10d' sedtest.txt

删除6-10行的内容,包括6和10

sed -e "2d" sedtest.txt

删除第2行的内容

sed "1,/^$/d" sedtest.txt

删除从第一行到第一个空行之间的所有内容

注意这个命令很容易带来意外的结果,当sedtest.txt中从第一行开始并没有空行,则sed删

?nbsp;

?nbsp;

sed "1,/from/d" sedtest.txt

删除从第一行到第一个包含from字符串的行之间的所有内容,包括第一个包含

from字符串的行。

★替换匹配行 [/pattern/]c\ 或者 [address1][,address2]c\

sed -e "/is/c\\

**********" sedtest.txt

寻找所有包含is字符串的匹配行,替换成**********

**********

----------------------

**********

--------------------------------------------------------------------------------

While in some ways similar to an editor which permits script ed edits (such as ed )

,

--------------------------------------------------------------------------------

-

-

**********

-----------------------------------------------------------------------------

**********

--------------------------------------------------------------------------------

-

sed -e "1,11c\\

**********" sedtest.txt----------------------

在1-12行内搜索所有from字符串,分别替换成****字符串

★限定范围后的模式匹配

sed "/But/s/is/are/g" sedtest.txt

对那些包含But字符串的行,把is替换成are

sed "/is/s/t/T/" sedtest.txt

对那些包含is字符串的行,把每行第一个出现的t替换成T

sed "/While/,/from/p" sedtest.txt -n

输出在这两个模式匹配行之间的所有内容

★指定替换每一行中匹配的第几次出现

sed "s/is/are/5" sedtest.txt

把每行的is字符串的第5次出现替换成are

★ &代表最后匹配

sed "s/^$/(&)/" sedtest.txt

给所有空行增加一对()

sed "s/is/(&)/g" sedtest.txt

给所有is字符串外增加()

sed "s/.*/(&)/" sedtest.txt

给所有行增加一对()

sed "/is/s/.*/(&)/" sedtest.txt

给所有包含is字符串的行增加一对()

★利用sed修改PATH环境变量

先查看PATH环境变量

[scz@ /home/scz/src]> echo $PATH

/usr/bin:/usr/bin:/bin:/usr/local/bin:/sbin:/usr/sbin:/usr/X11R6/bin:.

去掉尾部的{ :/usr/X11R6/bin:. }

[scz@ /home/scz/src]> echo $PATH | sed "s/^\(.*\):\/usr[/]X11R6\/bin:[.]$/\1/" /usr/bin:/usr/bin:/bin:/usr/local/bin:/sbin:/usr/sbin

去掉中间的{ :/bin: }

[scz@ /home/scz/src]> echo $PATH | sed "s/^\(.*\):\/bin:\(.*\)$/\1\2/"

/usr/bin:/usr/bin/usr/local/bin:/sbin:/usr/sbin:/usr/X11R6/bin:.

[/]表示/失去特殊意义

\/同样表示/失去意义

\1表示子匹配的第一次出现

\2表示子匹配的第二次出现

\(.*\)表示子匹配

去掉尾部的:,然后增加新的路径

PATH=`echo $PATH | sed 's/\(.*\):$/\1/'`:$HOME/src

注意反引号`和单引号'的区别。

★测试并提高sed命令运行效率

time sed -n "1,12p" webkeeper.db > /dev/null

time sed 12q webkeeper.db > /dev/null

可以看出后者比前者效率高。

[address]q 当碰上指定行时退出sed执行

★指定输出文件 [address1][,address2]w outputfile

sed "1,10w sed.out" sedtest.txt -n

将sedtest.txt中1-10行的内容写到sed.out文件中。

★指定输入文件 [address]r inputfile

sed "1r sedappend.txt" sedtest.txt

将sedappend.txt中的内容附加到sedtest.txt文件的第一行之后

★替换相应字符 [address1][,address2]y/old/new/

sed "y/abcdef/ABCDEF/" sedtest.txt

将sedtest.txt中所有的abcdef小写字母替换成ABCDEF大写字母。

★ !号的使用

sed -e '3,7!d' sedtest.txt

删除3-7行之外的所有行

sed -e '1,/from/!d' sedtest.txt

找到包含from字符串的行,删除其后的所有行

★ \c正则表达式c 的使用

sed -e "\:from:d" sedtest.txt

等价于 sed -e "/from/d" sedtest.txt

★ sed命令中正则表达式的复杂性

cat > sedtest.txt

^\/[}]{.*}[\(]$\)

^D

如何才能把该行替换成

\(]$\)\/[}]{.*}^[

★转换man手册成普通文本格式(新)

man sed | col -b > sed.txt

sed -e "s/^H//g" -e "/^$/d" -e "s/^^I/ /g" -e "s/^I/ /g" sed.txt > sedman txt

删除所有退格键、空行,把行首的制表符替换成8个空格,其余制表符替换成一个空格。★ sed的man手册(用的就是上面的方法)

NAME

sed - a Stream EDitor

SYNOPSIS

sed [-n] [-V] [--quiet] [--silent] [--version] [--help]

[-e script] [--expression=script]

[-f script-file] [--file=script-file]

[script-if-no-other-script]

[file...]

DE script ION

Sed is a stream editor. A stream editor is used to per-

form basic text transformations on an input stream (a file

or input from a pipeline). While in some ways similar to

an editor which permits script ed edits (such as ed), sed

works by making only one pass over the input(s), and is

consequently more efficient. But it is sed's ability to

filter text in a pipeline which particularly distinguishes

it from other types of editors.

OPTIONS

Sed may be invoked with the following command-line

options:

-V

--version

Print out the version of sed that is being run and

a copyright notice, then exit.

-h

--help Print a usage message briefly summarizing these

command-line options and the bug-reporting address,

then exit.

-n

--quiet

--silent

By default, sed will print out the pattern space at

the end of each cycle through the script. These

options disable this automatic printing, and sed

will only produce output when explicitly told to

via the p command.

-e script

--expression=script

Add the commands in script to the set of commands

to be run while processing the input.

-f script-file

--file=script-file

Add the commands contained in the file script-file

to the set of commands to be run while processing

the input.

If no -e,-f,--expression, or --file options are given on

the command-line, then the first non-option argument on

the command line is taken to be the script to be executed.

If any command-line parameters remain after processing the above, these parameters are interpreted as the names of input files to be processed. A file name of - refers to

the standard input stream. The standard input will pro- cessed if no file names are specified.

Command Synopsis

This is just a brief synopsis of sed commands to serve as

a reminder to those who already know sed; other document a- tion (such as the texinfo document) must be consulted for fuller de script ions.

Zero-address ``commands''

: label

Label for b and t commands.

#comment

The comment extends until the next newline (or the

end of a -e script fragment).

} The closing bracket of a { } block.

Zero- or One- address commands

= Print the current line number.

a \

text Append text, which has each embedded newline pre- ceeded by a backslash.

i \

text Insert text, which has each embedded newline pre- ceeded by a backslash.

q Immediately quit the sed script without processing

any more input, except that if auto-print is not

diabled the current pattern space will be printed.

r filename

Append text read from filename.

Commands which accept address ranges

{ Begin a block of commands (end with a }).

b label

Branch to label; if label is omitted, branch to end

of script.

t label

If a s/// has done a successful substitution since

the last input line was read and since the last t command, then branch to label; if label is omitted, branch to end of script.

c \

text Replace the selected lines with text, which has each embedded newline preceeded by a backslash.

d Delet

e pattern space. Start next cycle.

D Delete up to the first embedded newline in the pat- tern space. Start next cycle, but skip reading

from the input if there is still data in the pat-

tern space.

h H Copy/append pattern space to hold space.

g G Copy/append hold space to pattern space.

x Exchange the contents of the hold and pattern spaces.

l List out the current line in a ``visually unambigu- ous'' form.

n N Read/append the next line of input into the pattern space.

p Print the current pattern space.

P Print up to the first embedded newline of the cur- rent pattern space.

s/regexp/replacement/

Attempt to match regexp against the pattern space.

If successful, replace that portion matched with replacement. The replacement may contain the spe- cial character & to refer to that portion of the

pattern space which matched, and the special escapes \1 through \9 to refer to the corresponding matching sub-expressions in the regexp.

w filename Write the current pattern space to file- name.

y/source/dest/

Transliterate the characters in the pattern space

which appear in source to the corresponding charac- ter in dest.

Addresses

Sed commands can be given with no addresses, in which case the command will be executed for all input lines; with one address, in which case the command will only be executed

for input lines which match that address; or with two addresses, in which case the command will be executed for all input lines which match the inclusive range of lines starting from the first address and continuing to the sec-

ond address. Three things to note about address ranges:

the syntax is addr1,addr2 (i.e., the addresses are sepa- rated by a comma); the line which addr1 matched will always be accepted, even if addr2 selects an earlier line;

and if addr2 is a regexp, it will not be tested against

the line that addr1 matched.

After the address (or address-range), and before the com- mand, a ! may be inserted, which specifies that the com- mand shall only be executed if the address (or address- range) does not match.

The following address types are supported:

number Match only the specified line number.

first~step

Match every step'th line starting with line first.

For example, ``sed -n 1~2p'' will print all the

odd-numbered lines in the input stream, and the

address 2~5 will match every fifth line, starting

with the second. (This is a GNU extension.)

$ Match the last line.

/regexp/

Match lines matching the regular expression regexp.

\cregexpc

Match lines matching the regular expression regexp.

The c may be any character.

Regular expressions

POSIX.2 BREs should be supported, but they aren't com- pletely yet. The \n sequence in a regular expression matches the newline character. There are also some GNU extensions. [XXX FIXME: more needs to be said. At the

very least, a reference to another document which describes what is supported should be given.] Miscellaneous notes

This version of sed supports a \ sequence in all regular expressions, the replacement part of a substitute (s) command, and in the source and dest parts of a transliterate (y) command. The \ is stripped, and the newline is kept.

SEE ALSO

awk(1), ed(1), expr(1), emacs(1), perl(1), tr(1), vi(1),

regex(5) [well, one ought to be written... XXX], https://www.360docs.net/doc/e2708711.html,,

any of various books on sed, the sed FAQ

(https://www.360docs.net/doc/e2708711.html,/sedtut10.txt,

https://www.360docs.net/doc/e2708711.html,/sed/sedfaq.htm).

BUGS

E-mail bug reports to bug-gnu-utils@https://www.360docs.net/doc/e2708711.html,. Be sure to

include the word ``sed'' somewhere in the ``Subject:''

field.

Sed学习笔记

--------------------------------------------------------------------------------

T able of Contents

1. Sed简介

2. 定址

3. Sed命令

4. 选项

5. 元字符集

6. 实例

7. 脚本

1. Sed简介

sed是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed 主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。以下介绍的是Gnu版本的Sed 3.02。

2. 定址

可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这两行为起止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($)表示最后一行。范围可以

通过数据,正则表达式或者二者结合的方式确定。

3. Sed命令

调用sed命令有两种形式:

sed [options] 'command' file(s)

sed [options] -f script file file(s)

a\

在当前行后面加入一行文本。

b lable

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

用新的文本改变本行的文本。

d

从模板块(Pattern space)位置删除行。

D

删除模板块的第一行。

i\

在当前行上面插入文本。

h

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

H

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

g

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

G

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

l

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

n

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

N

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

p

打印模板块的行。

P(大写)

打印模板块的第一行。

q

退出Sed。

r file

从file中读行。

t label

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

T label

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

w file

写并追加模板块到file末尾。

W file

写并追加模板块的第一行到file末尾。

!

表示后面的命令对所有没有被选定的行发生作用。

s/re/string

用string替换正则表达式re。

=

打印当前行号码。

#

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

以下的是替换标记

g表示行内全面替换。

p表示打印行。

w表示把行写入一个文件。

x表示互换模板块中的文本和缓冲区中的文本。

y表示把一个字符翻译为另外的字符(但是不用于正则表达式)4. 选项

-e command, --expression=command

允许多台编辑。

-h, --help

打印帮助,并显示bug列表的地址。

-n, --quiet, --silent

取消默认输出。

-f, --filer=script-file

引导sed脚本文件名。

-V, --version

打印版本和版权信息。

5. 元字符集

^ 锚定行的开始如:/^sed/匹配所有以sed开头的行。

$ 锚定行的结束如:/sed$/匹配所有以sed结尾的行。

. 匹配一个非换行符的字符如:/s.d/匹配s后接一个任意字符,然后是d。

* 匹配零或多个字符如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。

[] 匹配一个指定范围内的字符,如/[Ss]ed/匹配sed和Sed。

[^] 匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed的行。

\(..\) 保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers。

& 保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。

\< 锚定单词的开始,如:/\

\> 锚定单词的结束,如/love\>/匹配包含以love结尾的单词的行。

x\{m\}重复字符x,m次,如:/0\{5\}/匹配包含5个o的行。

x\{m,\} 重复字符x,至少m次,如:/o\{5,\}/匹配至少有5个o的行。

x\{m,n\}重复字符x,至少m次,不多于n次,如:/o\{5,10\}/匹配5--10个o的行。

6. 实例

删除:d命令

$ sed '2d' example-----删除example文件的第二行。

$ sed '2,$d' example-----删除example文件的第二行到末尾所有行。

$ sed '$d' example-----删除example文件的最后一行。

$ sed '/test/'d example-----删除example文件所有包含test的行。

替换:s命令

$ sed 's/test/mytest/g' example-----在整行范围内把test替换为mytest。如果没有g标记,则只有每行第一个匹配的test被替换成mytest。

$ sed -n 's/^test/mytest/p' example-----(-n)选项和p标志一起使用表示只打印那些发生替换的行。也就是说,如果某一行开头的test被替换成mytest,就打印它。

$ sed 's/^192.168.0.1/&localhost/' example-----&符号表示替换换字符串中被找到的部份。所有以192.168.0.1开头的行都会被替换成它自已加localhost,变成192.168.0.1localhost。

$ sed -n 's/\(love\)able/\1rs/p' example-----love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来。

$ sed 's#10#100#g' example-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。

选定行的范围:逗号

$ sed -n '/test/,/check/p' example-----所有在模板test和check所确定的范围内的行都被打印。

$ sed -n '5,/^test/p' example-----打印从第五行开始到第一个包含以test开始的行之间的所有行。

$ sed '/test/,/check/s/$/sed test/' example-----对于模板test和west之间的行,每行的末尾用字符串sed test替换。

多点编辑:e命令

$ sed -e '1,5d' -e 's/test/check/' example-----(-e)选项允许在同一行里执行多条命令。如例子所示,第一条命令删除1至5行,第二条命令用check替换test。命令的执行顺序对结果有影响。如果两个命令都是替换命令,那么第一个替换命令将影响第二个替换命令的结果。

$ sed --expression='s/test/check/' --expression='/love/d' example-----一个比-e更好的命令是

--expression。它能给sed表达式赋值。

从文件读入:r命令

$ sed '/test/r file' example-----file里的内容被读进来,显示在与test匹配的行后面,如果匹配多行,则file的内容将显示在所有匹配行的下面。

写入文件:w命令

$ sed -n '/test/w file' example-----在example中所有包含test的行都被写入file里。

追加命令:a命令

$ sed '/^test/a\\--->this is a example' example<-----'this is a example'被追加到以test开头的行后面,sed要求命令a后面有一个反斜杠。

插入:i命令

$ sed '/test/i\\

new line

-------------------------' example

如果test被匹配,则把反斜杠后面的文本插入到匹配行的前面。

下一个:n命令

$ sed '/test/{ n; s/aa/bb/; }' example-----如果test被匹配,则移动到匹配行的下一行,替换这一行的aa,变为bb,并打印该行,然后继续。

变形:y命令

$ sed '1,10y/abcde/ABCDE/' example-----把1--10行内所有abcde转变为大写,注意,正则表达式元字符不能使用这个命令。

退出:q命令

$ sed '10q' example-----打印完第10行后,退出sed。

保持和获取:h命令和G命令

$ sed -e '/test/h' -e '$G example-----在sed处理文件的时候,每一行都被保存在一个叫模式空间的临时缓冲区中,除非行被删除或者输出被取消,否则所有被处理的行都将打印在屏幕上。接着模式空间被

清空,并存入新的一行等待处理。在这个例子里,匹配test的行被找到后,将存入模式空间,h命令将其复制并存入一个称为保持缓存区的特殊缓冲区内。第二条语句的意思是,当到达最后一行后,G命令取出保持缓冲区的行,然后把它放回模式空间中,且追加到现在已经存在于模式空间中的行的末尾。在这个例子中就是追加到最后一行。简单来说,任何包含test的行都被复制并追加到该文件的末尾。

保持和互换:h命令和x命令

$ sed -e '/test/h' -e '/check/x' example -----互换模式空间和保持缓冲区的内容。也就是把包含test 与check的行互换。

7. 脚本

Sed脚本是一个sed的命令清单,启动Sed时以-f选项引导脚本文件名。Sed对于脚本中输入的命令非常挑剔,在命令的末尾不能有任何空白或文本,如果在一行中有多个命令,要用分号分隔。以#开头的行为注释行,且不能跨行。

awk命令的用法

awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。 awk有3个不同版本: awk、nawk和gawk,未作特别说明,一般指gawk,gawk 是AWK 的GNU 版本。 awk其名称得自于它的创始人Alfred Aho 、Peter Weinberger 和Brian Kernighan 姓氏的首个字母。实际上AWK 的确拥有自己的语言:AWK 程序设计语言,三位创建者已将它正式定义为“样式扫描和处理语言”。它允许您创建简短的程序,这些程序读取输入文件、为数据排序、处理数据、对输入执行计算以及生成报表,还有无数其他的功能。 使用方法 awk '{pattern + action}' {filenames} 尽管操作可能会很复杂,但语法总是这样,其中pattern 表示AWK 在数据中查找的内容,而action 是在找到匹配内容时所执行的一系列命令。花括号({})不需要在程序中始终出现,但它们用于根据特定的模式对一系列指令进行分组。pattern就是要表示的正则表达式,用斜杠括起来。 awk语言的最基本功能是在文件或者字符串中基于指定规则浏览和抽取信息,awk抽取信息后,才能进行其他文本操作。完整的awk脚本通常用来格式化文本文件中的信息。 通常,awk是以文件的一行为处理单位的。awk每接收文件的一行,然后执行相应的命令,来处理文本。 调用awk 有三种方式调用awk 1.命令行方式 awk [-F field-separator] 'commands' input-file(s) 其中,commands 是真正awk命令,[-F域分隔符]是可选的。input-file(s) 是待处理的文件。在awk中,文件的每一行中,由域分隔符分开的每一项称为一个域。通常,在不指名-F域分隔符的情况下,默认的域分隔符是空格。 2.shell脚本方式 将所有的awk命令插入一个文件,并使awk程序可执行,然后awk命令解释器作为脚本的首行,一遍通过键入脚本名称来调用。 相当于shell脚本首行的:#!/bin/sh 可以换成:#!/bin/awk 3.将所有的awk命令插入一个单独文件,然后调用: awk -f awk-script-file input-file(s) 其中,-f选项加载awk-script-file中的awk脚本,input-file(s)跟上面的是一样的。 本章重点介绍命令行方式。 入门实例 假设last -n 5的输出如下

[图文] linux sed入门的15个小操作

[图文] linux sed入门的15个小操作 E-mail:nathanielwen@https://www.360docs.net/doc/e2708711.html, 近期在学习Linux Shell编程中关于sed工具的部分,出于习惯,在经历各种百度、各种论坛、各种资料之后,一定会整理一份文档作为自己学习的小小总结,也希望可以帮助很多跟我一样渴望进入Linux世界的新手们,这里要推荐两个很好的资源: https://www.360docs.net/doc/e2708711.html,/command/ UNIX.shell范例精解(第4版) 这份文档里面的很多知识点,包括使用的databook文件等都来自于这两个资源,如果有侵犯版权问题,也请见谅~ 关于文档的几点说明: (没有耐心的童鞋可以跳过这一页) 1、注释部分用“#” 2、指令部分用黄色的底色标出,在其后附上指令运行截图 3、每个操作涉及的选项或者参数均用红色加粗字体显示 4、部分操作之后会附加知识点拓展和常用操作,希望可以更有效的使用sed工具 5、文档正文部分结束后附录I会有一些知识点的补充,难度上没有增加,只是不方便安排在常用操作中 6、关于元字符和正则表达式的部分,难度较大,再其他文档中会有讲解,或者也可以参阅《UNIX.shell范例精解(第4版)》,该书扫描版的pdf文档可以上网下载或者发邮箱联系我,很欢迎可以分享优秀的资源 7、文档的附录II部分,列出了文件databook的内容 我也是新手,理解能力,表达能力不足,很多内容不可能面面俱到,同时,必然也会存在很多纰漏,希望大家指正、见谅,我已经尽力了,thank you~

#首先介绍一下命令的基本格式: sed [options] '{command}' [filename] 例如sed -n '1,3p' databook 出于个人习惯在接下来的例子中,通常将命令等价的表示为 cat filename | sed [options] '{command}' 例如 cat databook | sed -n '1,3p' #在正式开始之前,我们还需要一个用于操作的文本文件datafile,该文件会在附在附录II 里 #操作一:“s”参数,替换某个单词,例如将Steve Blenheim替换为Steve Jobs 为了方便阅读,我们将第一行截取,存至temp文件 cat databook | head -n 1 > temp (这里的“>”是重定向符号,将默认显示在终端上的内容,写入到temp文件中)

批量替换命令(sed)

原文地址 https://www.360docs.net/doc/e2708711.html,/2009/10/unix -sed -tutorial-advanced-sed -substitutio n-examples/ 发现thegeekstuff 确实是个不错的网站,一周推送geek 教程,看了后受益颇深,特此分享此为不完整译文加上本人一些理解 1.Sed 替换分隔符 除了\外,其他的字符都可以当作Sed 的替换分隔符,如 @ % | ; : 首先创建一个输入文件path.txt 1 2 3 4 $ cat path.txt /usr/kbos/bin:/usr/local/bin:/usr/jbin:/usr/bin:/usr/sas/bin /usr/local/sbin:/sbin:/bin/:/usr/sbin:/usr/bin:/opt/omni/bin: /opt/omni/lbin :/opt/omni/sbin:/root/bin 示例一,指定@为替换分隔符,把/opt/omni/lbin 替换为/opt/tools/bin 1 2 3 4 $ sed 's@/opt/omni/lbin@/opt/tools/bin@g' path.txt /usr/kbos/bin:/usr/local/bin:/usr/jbin/:/usr/bin:/usr/sas/bin /usr/local/sbin:/sbin:/bin/:/usr/sbin:/usr/bin:/opt/omni/bin: /opt/tools/bin :/opt/omni/sbin:/root/bin 示例二,如果指定/为分隔符,那么新旧字符串的/需要用\转义 1 2 3 4 $ sed 's/\/opt\/omni\/lbin/\/opt\/tools\/bin/g' path.txt /usr/kbos/bin:/usr/local/bin:/usr/jbin/:/usr/bin:/usr/sas/bin /usr/local/sbin:/sbin:/bin/:/usr/sbin:/usr/bin:/opt/omni/bin: /opt/tools/bin :/opt/omni/sbin:/root/bin 2,使用 '&' 得到匹配的字符串 示例一,替换/usr/bin/为/usr/bin/local 1 2 3 4 $ sed 's@/usr/bin@&/local@g' path.txt /usr/kbos/bin:/usr/local/bin:/usr/jbin/:/usr/bin/local :/usr/sas/bin /usr/local/sbin:/sbin:/bin/:/usr/sbin:/usr/bin/local :/opt/omni/bin: /opt/omni/lbin:/opt/omni/sbin:/root/bin 示例二,使用&匹配整行

Linux命令

tar grep find ssh sed awk vim diff sort export args ls pwd cd gzip bzip2unzip shutdown ftp crontab service ps free top df kill rm cp mv cat mount chmod chown passwd mkdir ifconfig uname whereis whatis locate man tail less su mysql yum rpm ping date wget 1. tar 创建一个新的tar文件 $ tar cvf archive_name.tar dirname/ 解压tar文件 $ tar xvf archive_name.tar 查看tar文件 $ tar tvf archive_name.tar 更多示例:The Ultimate Tar Command Tutorial with 10 Practical Examples 2. grep 在文件中查找字符串(不区分大小写) $ grep -i "the" demo_file 输出成功匹配的行,以及该行之后的三行 $ grep -A 3 -i "example" demo_text 在一个文件夹中递归查询包含指定字符串的文件

$ grep -r "ramesh" * 更多示例:Get a Grip on the Grep! – 15 Practical Grep Command Examples 3. find 查找指定文件名的文件(不区分大小写) $ find -iname "MyProgram.c" 对找到的文件执行某个命令 $ find -iname "MyProgram.c" -exec md5sum {} \; 查找home目录下的所有空文件 $ find ~ -empty 更多示例:Mommy, I found it! — 15 Practical Linux Find Command Examples 4. ssh 登录到远程主机 $ ssh -l jsmith https://www.360docs.net/doc/e2708711.html, 调试ssh客户端 $ ssh -v -l jsmith https://www.360docs.net/doc/e2708711.html, 显示ssh客户端版本

LINUX sed 使用

LINUX SED 1. Sed简介 2. 定址 3. Sed命令 4. 选项 5. 元字符集 6. 实例 7. 脚本 1. Sed简介 sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。以下介绍的是Gnu版本的Sed 3.02。 2. 定址 可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这两行为起止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($)表示最后一行。范围可以通过数据,正则表达式或者二者结合的方式确定。 3. Sed命令 调用sed命令有两种形式: * sed [options] 'command' file(s) * sed [options] -f scriptfile file(s) a\ 在当前行后面加入一行文本。 b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。 c\ 用新的文本改变本行的文本。 d 从模板块(Pattern space)位置删除行。 D 删除模板块的第一行。 i\ 在当前行上面插入文本。 h 拷贝模板块的内容到内存中的缓冲区。 H 追加模板块的内容到内存中的缓冲区 g

获得内存缓冲区的内容,并替代当前模板块中的文本。 G 获得内存缓冲区的内容,并追加到当前模板块文本的后面。 l 列表不能打印字符的清单。 n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。 N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。 p 打印模板块的行。 P(大写) 打印模板块的第一行。 q 退出Sed。 r file 从file中读行。 t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。 T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。 w file 写并追加模板块到file末尾。 W file 写并追加模板块的第一行到file末尾。 ! 表示后面的命令对所有没有被选定的行发生作用。 s/re/string 用string替换正则表达式re。 = 打印当前行号码。 # 把注释扩展到下一个换行符以前。 以下的是替换标记 * g表示行内全面替换。 * p表示打印行。 * w表示把行写入一个文件。 * x表示互换模板块中的文本和缓冲区中的文本。

sed替换命令

sed替换 让我们看一下 sed 最有用的命令之一,替换命令。使用该命令,可以将特定字符串或匹配的规则表达式用另一个字符串替换。下面是该命令最基本用法的示例: Linux代码 1.$ sed -e 's/foo/bar/' myfile.txt 上面的命令将 myfile.txt 中每行第一次出现的 'foo'(如果有的话)用字符串'bar' 替换,然后将该文件内容输出到标准输出。请注意,我说的是每行第一次出现,尽管这通常不是您想要的。在进行字符串替换时,通常想执行全局替换。也就是说,要替换每行中的所有出现,如下所示: Linux代码 1.$ sed -e 's/foo/bar/g' myfile.txt 在最后一个斜杠之后附加的 'g' 选项告诉 sed 执行全局替换。 关于 's///' 替换命令,还有其它几件要了解的事。首先,它是一个命令,并且只是一个命令,在所有上例中都没有指定地址。这意味着,'s///' 还可以与地址一起使用来控制要将命令应用到哪些行,如下所示: Linux代码 1.$ sed -e '1,10s/enchantment/entrapment/g' myfile 2.txt 上例将导致用短语 'entrapment' 替换所有出现的短语 'enchantment',但是只在第一到第十行(包括这两行)上这样做。 Linux代码 1.$ sed -e '/^$/,/^END/s/hills/mountains/g' myfile3.txt

该例将用 'mountains' 替换 'hills',但是,只从空行开始,到以三个字符 'END' 开始的行结束(包括这两行)的文本块上这样做。 关于 's///' 命令的另一个妙处是 '/' 分隔符有许多替换选项。如果正在执行字符串替换,并且规则表达式或替换字符串中有许多斜杠,则可以通过在 's' 之后指定一个不同的字符来更改分隔符。例如,下例将把所有出现的 /usr/local 替换成 /usr: Linux代码 1.$ sed -e 's:/usr/local:/usr:g' mylist.txt 在该例中,使用冒号作为分隔符。如果不指定分隔符,则变成了如下: Linux代码 1.$ sed -e 's/usr/local/usrg' mylist.txt 这样就不能执行了 如果需要在规则表达式中指定分隔符字符,可以在它前面加入反斜杠。 规则表达式混乱 目前为止,我们只执行了简单的字符串替换。虽然这很方便,但是我们还可以匹配规则表达式。例如,以下 sed 命令将匹配从 '<' 开始、到 '>' 结束、并且在其中包含任意数量字符的短语。下例将删除该短语(用空字符串替换): Linux代码 1.$ sed -e 's/<.*>//g' myfile.html 这是要从文件除去 HTML 标记的第一个很好的 sed 脚本尝试,但是由于规则表达式的特有规则,它不会很好地工作。原因何在?当 sed 试图在行中匹配规则表达式时,它要在行中查找最长的匹配。在我的前一篇 sed 文章中,这不成问题,因为我们使用的是 'd' 和 'p' 命令,这些命令总要删除或打印整行。但是,在使用 's///' 命令时,确实有很大不同,因为规则表达式匹配的整个部分将被

常用LINUX命令及脚本

常用LINUX命令及shell脚本 说明:本文档介绍的命令只说明比较有用的参数,要查看命令详情请‘MAN‘ 第一部分常用LINUX命令 (1) 1,基础命令 (1) 2,系统性能情况查看命令 (5) 3,网络命令 (6) 4,日志处理 (7) 5,其它命令 (9) 第二部分ftp命令说明 (9) 第三部分shell脚本 (10) 1批量创建目录 (10) 2,过滤出日志中昨天产生的线程挂起日志及详情代码 (11) 第一部分常用LINUX命令 1,基础命令 who 用于查看当前在线上的用户情况 参数: -m 显示当前用户名及详情 -q 显示用户的登陆帐号和登陆用户的数量 w 显示目前登入系统的用户信息 参数: -f 开启显示用户从何处登入系统 范例: was@linux-was:/tmp> w -f 00:55:11 up 48 min, 1 user, load average: 0.00, 0.02, 1.86 USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT was pts/0 192.168.10.2 00:30 0.00s 0.84s 0.00s w –f JCPU指的是与该tty终端连接的所由进程占用的时间,不包括过去的后台作业时间;PCPU 指

的是当前进程(即w项中显示的)所占用的时间 id 查看显示目前登陆账户的uid和gid及所属分组及用户名 linux-was:~ # id uid=0(root) gid=0(root) groups=0(root) was@linux-was:/tmp> id uid=1000(was) gid=100(users) groups=16(dialout),33(video),100(users) hostname 显示当前主机名 ls 显示当前文件和目录 参数: -l 列出文件的详细信息 -a 列出目录下的所有文件,包括以 . 开头的隐含文件 -t 以时间排序 -r 对目录反向排序 -S 按文件大小排序 同时此命令也可查看文件或目录权限 pwd 查看”当前工作目录“的完整路径 当你在终端进行操作时,你都会有一个当前工作目录。 在不太确定当前位置时,就会使用pwd来判定当前目录在文件系统内的确切位置 参数: -P 输出物理路径,针对链接的参数 cd 进入特定的目录 参数: /指定目录进入指定的目录 .. 返回上一级目录 touch 创建文件 mkdir 创建目录 参数: -p 此时若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录

sed命令用法

sed命令行格式为: sed [-nefri] ‘command’输入文本/文件 常用选项: -n∶取消默认的输出,使用安静(silent)模式。在一般sed 的用法中,所有来自STDIN的资料一般都会被列出到屏幕上。但如果加上-n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来 -e∶进行多项编辑,即对输入行应用多条sed命令时使用. 直接在指令列模式上进行sed 的动作编辑 -f∶指定sed脚本的文件名. 直接将sed 的动作写在一个档案内,-f filename 则可以执行filename 内的sed 动作 -r∶sed 的动作支援的是延伸型正则表达式的语法。(预设是基础正则表达式语法) -i∶直接修改读取的文件内容,而不是由屏幕输出 常用命令: a ∶新增,a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行) c ∶取代,c 的后面可以接字串,这些字串可以取代n1,n2 之间的行 d ∶删除,因为是删除,所以d 后面通常不接任何内容 i ∶插入,i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行) p∶列印,亦即将某个选择的资料印出。通常p 会与参数sed -n 一起用 s∶取代,可以直接进行替换的工作。通常这个s 的动作可以搭配正则表达式。例如 1,20s/old/new/g 定址 定址用于决定对哪些行进行编辑。地址的形式可以是数字、正则表达式、或二者的结合。如果没有指定地址,sed将处理输入文件的所有行。 地址是一个数字,则表示行号;是“$"符号,则表示最后一行。例如: sed -n '3p'datafile 只打印第三行 只显示指定行范围的文件内容,例如: # 只查看文件的第100行到第200行 sed -n '100,200p' mysql_slow_query.log 地址是逗号分隔的,那么需要处理的地址是这两行之间的范围(包括这两行在内)。范围可以用数字、正则表达式、或二者的组合表示。例如:

Linux命令集

文件和目录 cd /home 进入'/ home' 目录' cd .. 返回上一级目录 cd ../.. 返回上两级目录 cd 进入个人的主目录 cd ~user1 进入个人的主目录 cd - 返回上次所在的目录 pwd 显示工作路径 ls 查看目录中的文件 ls -F 查看目录中的文件 ls -l 显示文件和目录的详细资料 ls -a 显示隐藏文件 ls *[0-9]* 显示包含数字的文件名和目录名 tree 显示文件和目录由根目录开始的树形结构(1) lstree 显示文件和目录由根目录开始的树形结构(2) mkdir dir1 创建一个叫做'dir1' 的目录' mkdir dir1 dir2 同时创建两个目录 mkdir -p /tmp/dir1/dir2 创建一个目录树 rm -f file1 删除一个叫做'file1' 的文件' rmdir dir1 删除一个叫做'dir1' 的目录' rm -rf dir1 删除一个叫做'dir1' 的目录并同时删除其内容rm -rf dir1 dir2 同时删除两个目录及它们的内容 mv dir1 new_dir 重命名/移动一个目录 cp file1 file2 复制一个文件 cp dir/* . 复制一个目录下的所有文件到当前工作目录 cp -a /tmp/dir1 . 复制一个目录到当前工作目录 cp -a dir1 dir2 复制一个目录 ln -s file1 lnk1 创建一个指向文件或目录的软链接

ln file1 lnk1 创建一个指向文件或目录的物理链接 touch -t 0712250000 file1 修改一个文件或目录的时间戳- (YYMMDDhhmm) file file1 outputs the mime type of the file as text iconv -l 列出已知的编码 iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding. find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60 "thumbs/{}" \; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick) 文件搜索 find / -name file1 从'/' 开始进入根文件系统搜索文件和目录 find / -user user1 搜索属于用户'user1' 的文件和目录 find /home/user1 -name \*.bin 在目录'/ home/user1' 中搜索带有'.bin' 结尾的文件 find /usr/bin -type f -atime +100 搜索在过去100天内未被使用过的执行文件 find /usr/bin -type f -mtime -10 搜索在10天内被创建或者修改过的文件 find / -name \*.rpm -exec chmod 755 '{}' \; 搜索以'.rpm' 结尾的文件并定义其权限 find / -xdev -name \*.rpm 搜索以'.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备 locate \*.ps 寻找以'.ps' 结尾的文件- 先运行'updatedb' 命令 whereis halt 显示一个二进制文件、源码或man的位置 which halt 显示一个二进制文件或可执行文件的完整路径

sed简单应用实例及详解

$ sed -n '/test/w file' example-----在example中所有包含test的行都被写入file里。 追加命令:a命令 * $ sed '/^test/a\\--->this is a example' example<-----'this is a example'被追加到以test开头的行后面,sed要求命令a后面有一个反斜杠。 插入:i命令 $ sed '/test/i\\ new line -------------------------' example 如果test被匹配,则把反斜杠后面的文本插入到匹配行的前面。 下一个:n命令 * $ sed '/test/{ n; s/aa/bb/; }' example-----如果test被匹配,则移动到匹配行的下一行,替换这一行的aa,变为bb,并打印该行,然后继续。 变形:y命令 * $ sed '1,10y/abcde/ABCDE/' example-----把1--10行内所有abcde转变为大写,注意,正则表达式元字符不能使用这个命令。 退出:q命令 * $ sed '10q' example-----打印完第10行后,退出sed。 保持和获取:h命令和G命令 * $ sed -e '/test/h' -e '$G example-----在sed处理文件的时候,每一行都被保存在一个叫模式空间的临时缓冲区中,除非行被删除或者输出被取消,否则所有被处理的行都将打印在屏幕上。接着模式空间被清空,并存入新的一行等待处理。在这个例子里,匹配test的行被找到后,将存入模式空间,h命令将其复制并存入一个称为保持缓存区的特殊缓冲区内。第二条语句的意思是,当到达最后一行后,G命令取出保持缓冲区的行,然后把它放回模式空间中,且追加到现在已经存在于模式空间中的行的末尾。在这个例子中就是追加到最后一行。简单来说,任何包含test的行都被复制并追加到该文件的末尾。 保持和互换:h命令和x命令 * $ sed -e '/test/h' -e '/check/x' example -----互换模式空间和保持缓冲区的内容。也就是把包含test与check的行互换。 7. 脚本 Sed脚本是一个sed的命令清单,启动Sed时以-f选项引导脚本文件名。Sed对于脚本中输入的命令非常挑剔,在命令的末尾不能有任何空白或文本,如果在一行中有多个命令,要用分号分隔。以#开头的行为注释行,且不能跨行。

西班牙语命令式变位和用法总结

西班牙语命令式变位和 用法总结 Modified by JACK on the afternoon of December 26, 2020

西语堂--西班牙语命令式变位和用法总结 一.肯定命令式变位和用法总结。 1.肯定命令式的变位。(命令式只有现在时态,没有第一人称“我”。)规则动词的变位。例如: verbo túusted nosotros vosotros ustedes cantar cant a cant e cant emos cant ad cant en comer com e com a com amos com ed com an vivir viv e viv a viv amos viv id viv an 常用不规则动词的变位。见下表: verbo túusted Nosotros vosotros ustedes ir ve vaya vayamos id vayan venir ven venga vengamos venid vengan

hacer haz haga hagamos haced hagan decir di diga digamos Decid digan salir sal salga salgamos salid salgan Oír oye oiga oigamos oíd oigan ser sésea seamos sed sean tener ten tenga tengamos tened tengan Poner pon ponga pongamos poned pongan 2. 肯定命令式使用时应注意的几点: 直接宾语代词和间接宾语代词都应直接连写在变位动词后面,顺序为间宾在 前,直宾在后,并且在变位动词重读音节加上重音符号。 例如: Dímelo . límpiatelas . llévenselo . póngaselos .

linux之sed用法汇总

Linux命令之sed基本用法 sed命令格式: Sed [选项] '条件指令' 文件 选项: -n 屏蔽默认输出 -r 支持扩展正则 -i 修改源文件 条件: 行号4 4,5 4~2 4,+10 /正则/ 指令: p 打印 d 删除 s 替换s/旧/新/g a 追加 i 插入 c 替换行

[qh@root test]$ cat test.txt 星期一 星期二 星期三 星期四 一、sed命令的-n 选项: 1)输出文件第N行内容(若不加-n ,则打印全部内容且第1行重复2次)[qh@root test]$ sed -n ‘1p’test.txt 星期一 [qh@root test]$ sed ‘1p’test.txt 星期一 星期一 星期二 星期三 星期四 2)指定打印第2行到第4行的文件内容 [qh@root test]$ sed -n ‘2,4p’test.txt 星期二 星期三

星期四 3)指定打印第1行和4行的文件内容 [qh@root test]$ sed -n ‘1p;4p’test.txt 星期一 星期四 4)打印第2行以及后面的10行 [qh@root test]$ sed -n ‘2p,+10p’test.txt 星期二 星期三 星期四 。。。。。。 5)打印奇数行 [qh@root test]$ sed -n ‘1~2p’test.txt 星期一 星期三 6)打印偶数行 [qh@root test]$ sed -n ‘2~2p’test.txt 星期二 星期四

二、sed命令的-i 选项: 1),sed命令所做的处理只是把操作结果(包括打印、删除等)输出到当前终端屏幕,而并不会对原始文件做任何更改: 删除所有行 [qh@root test]$ sed ‘d’test.txt 查看文件内容,发现并未改动 [qh@root test]$ cat test.txt 星期一 星期二 星期三 星期四 #若希望直接修改文件内容,应添加选项-i [qh@root test]$ sed -i ‘d’test.txt 发现文件内容已删除 [qh@root test]$ cat test.txt

sed_4.2.1_man_中文

本文参照sed 4.2.1的man原文翻译。蓝色字体为man原文,黑色字体是我的译文。 水平有限,难免错漏,欢迎各位指正! GNU文档的精髓在info页,而不是man页。 当然更希望有同仁将sed的info页翻译出来,方便大家更扎实地运用好sed这个功能强大的工具。 翻译者:李启训。 NAME 名称 sed - stream editor for filtering and transforming text 用于过滤和转换文本的流编辑器。 SYNOPSIS 提要 sed [OPTION]... {script-only-if-no-other-script} [input-file]... DESCRIPTION 描述 Sed is a stream editor. A stream editor is used to perform basic text transformations on an input stream (a file or input from a pipeline). While in some ways similar to an editor which permits scripted edits (such as ed), sed works by making only one pass over the input(s), and is consequently more efficient. But it is sed's ability to filter text in a pipeline which particularly distinguishes it from other types of editors. Sed 是一个流编辑器。流编辑器用于转换输入流(文件或者来自管道)的基本文本。虽然在某些方面它类似于允许脚本编辑的编辑器(比如ed),但是sed只对一次传递的输入进行操作,当然更加高效。除此以外,因为sed能够过滤来自管道中的文本,这明显区别于其他类型的编辑器。 -n, --quiet, --silent suppress automatic printing of pattern space 抑制模式空间的自动输出。 -e script, --expression=script add the script to the commands to be executed 添加脚本给命令,以便执行。 -f script-file, --file=script-file add the contents of script-file to the commands to be executed 添加脚本文件的内容,以便执行。 --follow-symlinks follow symlinks when processing in place 就地处理时跟随符号链接。 -i[SUFFIX], --in-place[=SUFFIX] edit files in place (makes backup if extension supplied) 就地编辑文件(如果提供扩展,则备份文件)。 -l N, --line-length=N specify the desired line-wrap length for the `l' command 为l命令指定所预期的行的长度。 --posix disable all GNU extensions. 禁用所有GNU扩展。 -r, --regexp-extended use extended regular expressions in the script. 在脚本中使用扩展正则表达式。 -s, --separate consider files as separate rather than as a single continuous

西班牙语命令式变位和用法总结

西语堂--西班牙语命令式变位和用法总结 一.肯定命令式变位和用法总结。 1.肯定命令式的变位。(命令式只有现在时态,没有第一人称“我”。)规则动词的变位。例如: verbo túusted nosotros vosotros ustedes cantar cant a cant e cant emos cant ad cant en comer com e com a com amos com ed com an vivir viv e viv a viv amos viv id viv an 常用不规则动词的变位。见下表: verbo túusted Nosotros vosotros ustedes ir ve vaya vayamos id vayan venir ven venga vengamos venid vengan

hacer haz haga hagamos haced hagan decir di diga digamos Decid digan salir sal salga salgamos salid salgan Oír oye oiga oigamos oíd oigan ser sésea seamos sed sean tener ten tenga tengamos tened tengan Poner pon ponga pongamos poned pongan 2. 肯定命令式使用时应注意的几点: 直接宾语代词和间接宾语代词都应直接连写在变位动词后面,顺序为间宾在 前,直宾在后,并且在变位动词重读音节加上重音符号。 例如: Dímelo . límpiatelas . llévenselo . póngaselos .

sight的用法总结大全

sight的用法总结大全 sight有视力,看见,视野,景象的意思。那你们想知道sight的用法吗?今天给大家带来了sight的用法,希望能够帮助到大家,一起来学习吧。 sight的用法总结大全 sight的意思 n. 视力,看见,视野,景象 vt. 看见,发现,瞄准,观察,调准瞄准器 vi. (用仪器)瞄准,观察 变形:过去式: sighted; 现在分词:sighting; 过去分词:sighted; sight用法 sight可以用作名词 sight用作名词的基本意思是“视力,视觉”,也可指“看见,瞥见”“视域,眼界”等,是不可数名词。引申可表示“情景,景象”,是可数名词; 还可指“风景,名胜”“(步枪等的)瞄准器,观测器”,常用于复数形式。

sight作“视域,眼界”解时,常与介词in(to)连用。 a sight除了可用于表示“一处景象”或“一个瞄准器”之外,在口语中还可指“显得滑稽可笑的、不整洁的人或物”“非常,很多”等。作“非常,很多”解时,其后常接介词of。 sight用作名词的用法例句 Im having laser treatment to improve my sight.我正在接受激光治疗来提高我的视力。 The captain ordered us to shoot any strangers on sight.船长命令我们凡是看见的陌生人都要将其枪毙。 The train is still in sight.火车仍在视线内。 sight可以用作动词 sight用作动词时基本意思是“看见,发现”,尤指观望一阵之后才得以“看见或发现…”,此时通常用作及物动词,接名词或代词作宾语,可用于被动结构。 sight还可表示“(用仪器)瞄准〔观测,察看〕”,既可用作及物动词,也可用作不及物动词,用作及物动词时,接名词或代词作宾语。 sight有时还可表示“调整(枪、炮等的)瞄准器”,用作及物动词。

linux sed命令参数及用法详解

sed sed 编辑器是 Linux 系统管理员的工具包中最有用的资产之一, 因此,有必要彻底地了解其应用 Linux 操作系统最大的一个好处是它带有各种各样的实用工具。存在如此之多不同的实用工具,几乎不可能知道并了解所有这些工具。可以简化关键情况下操作的一个实用工具是 sed。它是任何管理员的工具包中最强大的工具之一,并且可以证明它自己在关键情况下非常有价值。 sed 实用工具是一个“编辑器”,但它与其它大多数编辑器不同。除了不面向屏幕之外,它还是非交互式的。这意味着您必须将要对数据执行的命令插入到命令行或要处理的脚本中。当显示它时,请忘记您在使用 Microsoft Word 或其它大多数编辑器时拥有的交互式编辑文件功能。sed 在一个文件(或文件集)中非交互式、并且不加询问地接收一系列的命令并执行它们。因而,它流经文本就如同水流经溪流一样,因而 sed 恰当地代表了流编辑器。它可以用来将所有出现的 "Mr. Smyth" 修改为 "Mr. Smith",或将 "tiger cub" 修改为 "wolf cub"。流编辑器非常适合于执行重复的编辑,这种重复编辑如果由人工完成将花费大量的时间。其参数可能和一次性使用一个简单的操作所需的参数一样有限,或者和一个具有成千上万行要进行编辑修改的脚本文件一样复杂。sed 是 Linux 和UNIX 工具箱中最有用的工具之一,且使用的参数非常少。 sed 的工作方式 sed 实用工具按顺序逐行将文件读入到内存中。然后,它执行为该行指定的所有操作,并在完成请求的修改之后将该行放回到内存中,以将其转储至终端。完成了这一行上的所有操作之后,它读取文件的下一行,然后重复该过程直到它完成该文件。如同前面所提到的,默认输出是将每一行的内容输出到屏幕上。在这里,开始涉及到两个重要的因素—首先,输出可以被重定向到另一文件中,以保存变化;第二,源文件(默认地)保持不被修改。sed 默认读取整个文件并对其中的每一行进行修改。不过,可以按需要将操作限制在指定的行上。 该实用工具的语法为: sed [options] '{command}' [filename] 在这篇文章中,我们将浏览最常用的命令和选项,并演示它们如何工作,以及它们适于在何处使用。 替换命令 sed 实用工具以及其它任何类似的编辑器的最常用的命令之一是用一个值替换

linux Sed命令详解

linux sed命令详解 1. Sed简介 sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区 中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成 后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并 没有改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文 件的反复操作;编写转换程序等。以下介绍的是Gnu版本的Sed 3.02。 2. 定址 可以通过定址来定位你所希望编辑的行,该地址用数字构成,用逗号分隔的两个行数表示以这 两行为起止的行的范围(包括行数表示的那两行)。如1,3表示1,2,3行,美元符号($) 表示最后一行。范围可以通过数据,正则表达式或者二者结合的方式确定。 3. Sed命令 1)调用sed命令有两种形式: 2)sed [options] 'command' file(s) 3)sed [options] -f scriptfile file(s) 4)a\ 在当前行后面加入一行文本。 5)b lable 分支到脚本中带有标记的地方,如果分支不存在则分支到脚本的末尾。 6)c\ 用新的文本改变本行的文本。 7)d 从模板块(Pattern space)位置删除行。 8)D 删除模板块的第一行。 9)i\ 在当前行上面插入文本。 10)h 拷贝模板块的内容到内存中的缓冲区。 11)H 追加模板块的内容到内存中的缓冲区

12)g 获得内存缓冲区的内容,并替代当前模板块中的文本。 13)G 获得内存缓冲区的内容,并追加到当前模板块文本的后面。 14)l 列表不能打印字符的清单。 15)n 读取下一个输入行,用下一个命令处理新的行而不是用第一个命令。 16)N 追加下一个输入行到模板块后面并在二者间嵌入一个新行,改变当前行号码。 17)p 打印模板块的行。 18)P(大写)打印模板块的第一行。 19)q 退出Sed。 20)r file 从file中读行。 21)t label if分支,从最后一行开始,条件一旦满足或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。 22)T label 错误分支,从最后一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令处,或者到脚本的末尾。 23)w file 写并追加模板块到file末尾。 24)W file 写并追加模板块的第一行到file末尾。 25)! 表示后面的命令对所有没有被选定的行发生作用。 26)s/re/string 用string替换正则表达式re。 27)= 打印当前行号码。 28)# 把注释扩展到下一个换行符以前。 以下的是替换标记 1)g表示行内全面替换。 2)p表示打印行。 3)w表示把行写入一个文件。 4)x表示互换模板块中的文本和缓冲区中的文本。

相关文档
最新文档