sed命令删除包含指定字符串行的上一行

+ echo x

sed

sed替换换行符 sed替换回车换行符sed替换换行符 sed替换回车换行符


sed替换换行符 sed替换回车换行符


sed替换换行符 sed替换回车换行符


'N;/n.关键字/!P;D'

文件名

直接对文件进行修echo $X|sed 's/ /n/g'改

N;

——多.关键字行模式,读入下一行

n——匹配换行符,保证后面搜索内容是在第二行中

——点星是任意字符,后面是搜索内容

//!P;

——前面的正则没有搜到(没有匹配)则执行多行打印【模式空间中的两行都打印】

D——模式空间中的两行全部删除【并再读入下一行】

正则表达式如何匹配换行符

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

n 是回车换行,就是光标移动到下一行,从下一行开始输入输出。跟换行符效果一样。

正则表达式,又称正规表示法、常规表示法(英语:Regular Expression,在代码中常简写为regex、regexp或RE),计算机科学的+ sed 's/ /n/g'一个概念。正则表达式使用单个字符串来描述、匹配一系列符合某个句法规则的字符串。在很多文本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。

许多程序设计语言都支持利用OFS :输出字段分隔符,默认值与输入字段分隔符一致。正则表达式进行字符串作。例如,在Perl中就内建了一个功能强大的正则表达式引擎。正则表达式这个概念初是由Unix中的工具软件(例如sed和grep)普及开的。正则表达式通常缩写成“regex”,单数有regexp、regex,复数有regexps、regexes、regexen。

匹配换行符n(.)

SPIDn(.)END完全可以

Shell编程之正则表达式(sed)

===========================================

sed 是一个流编辑器,读取文件一行,存放在缓存区,

sed功能很强,支持增、删、改(替换)、查。

与grep一样,sed在文件中查找模式时也可以使用正则表达式(ER)和各种元字符。

使用基本的元字符集^,$,,[],[^],<>,(),{}使用扩展元字符集?,+,{},|,()

sed对指定进行作,包括打印、删除、修改、追加等

-e 允许多项编辑

-n 取消默认的输出

-i 直接修改对应文件

-r 支持扩展元字符

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

a 在当前行后添加啊一行或多行

i 在当前行之前插入文本

d 在当前行进行删除作

p 打印匹配的行或指定行

n 读入下一输入行,从下一行命令进行处理!

对所选以外的所有行应用命令

h 把模式空间里的内容重定向到暂存缓存区

H 把模式空间里的内容追加到暂存缓冲区

g 取出暂存缓冲区的内容,将其到模式空间,覆盖该处原有内容

G 取出暂存缓冲区的内容,将其到模式空间,追加在原有内容后面

==================================

1)多重编辑选项e

//先删除行,然后管道给后面的sed进行替换

[root@shell ~]# sed '1,9d' passwd | sed 's#root#alex#g'

//使用-e进行多次编辑修改作

[root@shell ~]# sed -e '1,9d' -e 's#root#alex#g' passwd

打印匹配halt的行

[root@shell ~]# sed -n 'halt/p' passwd

打如果能看到文件存储的二进制字节,自然可以知道文件的行分隔符是什么,图形化的智能编辑器大部分都自带这个功能。命令行下也有好多工具可以查看文本文件的16进制输出,这里以xxd命令为例介绍(如下测试,连同本文的其他测试都是在 macOS Moje 版本号10.14.1 环境下执行的)。印第二行的内容

[root@shell ~]# sed -n '2p' passwd

bin:x:1:1:bin:/bin:/in:nologin

打印一行

[root@shell ~]# sed -n '$p' passwd

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

3)sed的追加方式

给30行添加配置

[root@shell ~]# sed -i '30a listen 80;' nginx.conf

在37行添加一条记录,t tab键(需要转义)

[root@shell ~]# sed -ri '37a t Listen 8080;' nginx.conf

在37行添加一条记录,n 换行符(需要转义)

[root@shell ~]# sed -r '37a n LIsten 8080;' nginx.conf

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

4)sed修改命令c

指定某行进行内容替换

[root@shell ~]# sed -i '7c SELINUX=Disabled' /etc/selinux/config

[root@shell ~]# sed -i '/^ server_name/c server_name liu' nginx.conf

//非交互式修改指定的配置文件

[root@shell ~]# sed -ri '/UseDNS/c UseDNS no' /etc/ssh/sshd_config

[root@shell ~]# sed -ri '/GSSAPIAuthentication/c #GSSAPIAuthentication no'

/etc/ssh/sshd_config

[root@shell ~]# sed -ri '/^SELINUX=/c SELINUX=disabled' /etc/selinux/config

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

5)-----------------------------------------------------------------------------删除命令d

//指定删除第三行,但不会改变文件内容

[root@shell ~]# sed '3d' passwd

[root@shell ~]# sed '3{d}' passwd

[root@shell ~]# sed '$d' passwd

//删除所有的行

[root@shell ~]# sed '1,$d' passwd

//匹配正则进行该行删除

例子:

[root@shell ~]# mysql -uroot -p345 -e "show databases;"

Database

rnamation_schema

mysql

performance_scheme

wordpress

[root@shell ~]# mysql -uroot -p345 -e "show databases;"|sed 1d

rnamation_schema

mysql

performance_scheme

wordpress

6)插入命令 i

//在文件的某一行上面添加内容

[root@shell ~]# sed -i '30i listen 80;' passwd

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

7)写文件命令w

//将匹配到的行写入到新的文件中

[root@shell ~]# sed -n '/root/w newfile' passwd

//将passwd文件的第二行写入到newfile中

[root@shell ~]# sed -n '2w newfile' passwd

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

8)获取下一行命令n

//匹配root的行,删除root行的下一列

[root@shell ~]# sed '/root/{n;d}' passwd

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

9)反向选择命令!

//除了第三行,其他全部删除

[root@shell ~]# sed -r '3!d' /etc/hosts

============(持续更新)============

“LINUX删掉换行符”是什么?

2)sed的打印-i//删除一行命令p

去掉文件中的换行符x0dx0a(1)tr命令的作是针对文件的作,它把整个文本当做作的对象,所以可以直接去除文件中的换行符x0dx0atr 'n' ' ' < filex0dx0a(2)sed的作对象是行.而作为行分割符号的回车符,本身是不属于行的.所以sed中必须加上N命令,把下一行的内容添加到当前的pattern space中,这样实际上是把相邻的2行合并了.下一次仍然是先n,再p,再N,开始新的轮回:x0dx0acat file | sed 'N;s/n/ /'x0dx0a所以上面的语句是不能把文件内容合并为一行的,到底该怎么写,我暂时没有想到,呵呵x0dx0a(3)直接用awkx0dx0aawk '{printf("%s ",$0)}' filex0dx0a(4)当然,用echo也是可以的:x0dx0awhile read line;do echo -n "$line"; done < awk_.txt, 这样,可以把awk_.txt的内容合并为一行x0dx0ased -e "s#[/r][/r][/n]#[/r][/n]#g" file

linux 三剑客(awk、sed、grep)

应用案例

可以根据文件指定分隔符,像处理表格一样处理文本或序列。通常来处理字段,并基于字段进行过滤,或进行模式匹配。

[root@shell ~]# sed /mail/d passwd

常用的内建变量

NF :记录的字段数

NR :记录的行号

ORS :输出记录分隔符(默认值是一个换行符)

$n :当前记录的第n个字段,字段间由FS分隔

$0 :完整的输入记录

ARGV :包含命令行参数的数组

ARGC :命令行参数的数目

基本用。而在下面的执行结果中,不难看出文件b.txt的行分隔符是法

awk 脚本

关于 awk 脚本,我们需要注意两个 BEGIN 和 END。

BEGIN{ 这里面放的是执行前的语句 }

END {这里面放的是处理完所有的行后要执行的语句 }

{这里面放的是处理每一行时要执行的语句

与awk 相比,sed在处理文本的行具有更好的效率。

基本语法

参数说明

sed 文件处理命令

包括增加、删除、打印、替换行的内容

以上的案例表明,sed 的一些作可以放在行的末尾,或者放在模式匹配的末尾,或者在大括号内以分号分隔,或者通过-e 命令,实现多点编辑。

grep 查找文件里符合条件的字符串。

grep 除了可以查找单个文件中匹配的模式,也可以在目录中包含特定字符的文件查找匹配模式的行。

linux sed echo命令

调用sed命令有两种形式:

1、创建a.sh

#!/bin/sh

set -x #加上调试

X="a b c"

Y="x y z"

Z=`echo $Y | sed "s/ /n/g"`

echo $Z

for str in $Z;do

echo $str

done

+ X='a b c'

+ echo a b c

ab

c+ Y='x y z'

++ echo x y z

+ Z='x

yz'

+ echo x y z

x y z

yz n'$!D: 删除模式行的部分并再次读取,循环此作直至文件末尾前的一行

xy使用扩展元字符的方式 + sed -r

z+ for str in '$Z'

x+ for str in '$Z'

+ echo y

+ echo z

z

Linux中的sed是什么意思呢,如何使用呢

c 在当前行进行替换修改

Sed是一项Linux指令,全称是Stream

EDitor,功能同awk类似,别在于,sed简单,对列处理的功能要一些,awk的功能复杂,对列处理的功能比较强大。Sed主要用于自动编辑一个或者多个文件,多用于脚本中对文件的处理。

Sed命令可以对文件进行增加、删除、修改和查找作,所以学好sed命令是写自动化脚本必须的基础之一。

sed [options] -f scriptfile file(s)

sed命令主要选项

-e command,--expression=command允许多台编辑。

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

-n,--quiet,--silent取消默认输出。

-f,--filer=script-filesed脚本文件名。

-V,--version打印版本和版权信息。

命令:

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

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

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

D 删除模板块的行。

i在当前行上面插入文本。

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

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

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

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

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

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

p 打印模板块的行。

P 打印模板块的行。

q 退出Sed。

r file从file中读行。

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

T label错误分支,从一行开始,一旦发生错误或者T,t命令,将导致分支到带有标号的命令Dos和windows采用回车+换行CR/LF表示下一行,即^M$处,或者到脚本的末尾。

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

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

s/re/string 用string替换正则表达式re。

= 打印当前行号码。

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

shell sed 如何删除多余的空行

print++ sed 's/ /n/g'f "$Z n"

1、除了换行符再没有其它字符的才算空行

sed '/^$/d' filename2、除 1 之外,只含有空格、tab 字符的行也算空行

sed '/^[[:space:]]$/d' filename

sed -i '/^$/d' file_name

直接删除文件sed选项参数中的空行

Shell脚本处理文本换行问题

原内容

sed [options] 'command' file(s)

使用正则匹配对应的内容,然后使用sed的c命令进行替换

yyyyyyyyyyy="eeeeeeeeeeeee">

通过命令

[root@localhost script]# cat test.wsdl |awk '{{printf"%s",$0}}'|sed -e 's//n/g'

思路是先去掉所有换行符,然后把替换为+换行

linux和dos下换行的不同表示

然后处理,输出。

关于回车和换行的历史。

回车和换行关于“回车”(carriage return)和“换行”(line feed)这两个概念的来历和区别。

而UNIX/Linux采用换行符LF表示下一行,即$

(MAC OS系统)则采用回车符CR表示下一行,即^M

LF使用'

一般作系统上的运行库会自动决定文本文件的换行格式. 如一个程序在windows上运行就生成CR/LF换行格式的文本文件,而在Linux上运行就生成LF格式换行的文本文件. 在一个平台上使用另一种换行符的文件文件可能会带来意想不到的问题, 特别是在编辑程序代码时. 有时候代码在编辑器中显示正常, 但在编辑时却会因为换行符问题而出错. 很多文本/代码编辑器带有换行符转换功能, 使用这个功能可以将文本文件中的换行符在不同格式单互换.

在不同平台间使用FTP软件传送文件时, 在ascii文本模式传输模式下, 一些FTP客户端程序会自动对换行格式进行转换. 经过这种传输的文件字节数可能会发生变化. 如果你不想ftp修改原文件, 可以使用bin模式(二进制模式)传输文本.

////////////////////////////////////////////////////////////////////////////////

一、windows的文件到linux下的转换方法:

tr2、sed有点复杂,以下是sed: -d "

4.使用dos2unix命令

# dos2unix -k hosts

5.用sed命令

二、Linux的文件到dos下的转换方法:

也可使用unix2dos命令。

三、其他