LINUX删掉换行符 5
我有个文件里想将某一行记录后面的换行符删掉,让2行变成一行,请问该怎么做。perlpi.back-e"s/\n//g"file.txt这个语法可以成功的将所有换行符删除,...
我有个文件里想将某一行记录后面的换行符删掉,让2行变成一行,请问该怎么做。
perl pi.back -e "s/\n//g" file.txt
这个语法 可以成功的将所有换行符删除,但是我想删的是特定行的换行符,shell中其他部分已经能精准定位到这一行了,就差删换行符。请指点。 展开
perl pi.back -e "s/\n//g" file.txt
这个语法 可以成功的将所有换行符删除,但是我想删的是特定行的换行符,shell中其他部分已经能精准定位到这一行了,就差删换行符。请指点。 展开
5个回答
展开全部
去掉文件中的换行符
(1)tr命令的操作是针对文件的操作,它把整个文本当做操作的对象,所以可以直接去除文件中的换行符
tr '\n' ' ' < file
(2)sed的操作对象是行.而作为行分割符号的回车符,本身是不属于行的.所以sed中必须加上N命令,把下一行的内容添加到当前的pattern space中,这样实际上是把相邻的2行合并了.下一次仍然是先n,再p,再N,开始新的轮回:
cat file | sed 'N;s/\n/ /'
所以上面的语句是不能把文件内容合并为一行的,到底该怎么写,我暂时没有想到,呵呵
(3)直接用awk
awk '{printf("%s ",$0)}' file
(4)当然,用echo也是可以的:
while read line;do echo -n "$line"; done < awk_help.txt, 这样,可以把awk_help.txt的内容合并为一行
sed -e "s#\[/r][/r][/n]#\[/r][/n]#g" file
(1)tr命令的操作是针对文件的操作,它把整个文本当做操作的对象,所以可以直接去除文件中的换行符
tr '\n' ' ' < file
(2)sed的操作对象是行.而作为行分割符号的回车符,本身是不属于行的.所以sed中必须加上N命令,把下一行的内容添加到当前的pattern space中,这样实际上是把相邻的2行合并了.下一次仍然是先n,再p,再N,开始新的轮回:
cat file | sed 'N;s/\n/ /'
所以上面的语句是不能把文件内容合并为一行的,到底该怎么写,我暂时没有想到,呵呵
(3)直接用awk
awk '{printf("%s ",$0)}' file
(4)当然,用echo也是可以的:
while read line;do echo -n "$line"; done < awk_help.txt, 这样,可以把awk_help.txt的内容合并为一行
sed -e "s#\[/r][/r][/n]#\[/r][/n]#g" file
展开全部
1、使用vim删除换行符
vim输入命令:%s/\n//g
2、使用sed命令,例如 sed ':t;N;s/\n//;b t' a.txt
结果:1,2,34,5,61,2,34,5,61,2,34,5,61,2,34,5,61,2,34,5,6
解释一下:
:t 定义label "t"b t 转到label "t" 继续执行
N 先读入一行到sed的模板空间,加个换行符(\n),再向sed模板空间追加下一行(之后sed 对模板空间中的内容执行s/\n/,/替换,并显示替换后的内容)
3、使用td命令,例如:
cat a.txt | tr '\n' ' '
1,2,3 4,5,6 1,2,3 4,5,6 1,2,3 4,5,6 1,2,3 4,5,6 1,2,3 4,5,6
注意tr最后那个参数是空格,否则会报错
vim输入命令:%s/\n//g
2、使用sed命令,例如 sed ':t;N;s/\n//;b t' a.txt
结果:1,2,34,5,61,2,34,5,61,2,34,5,61,2,34,5,61,2,34,5,6
解释一下:
:t 定义label "t"b t 转到label "t" 继续执行
N 先读入一行到sed的模板空间,加个换行符(\n),再向sed模板空间追加下一行(之后sed 对模板空间中的内容执行s/\n/,/替换,并显示替换后的内容)
3、使用td命令,例如:
cat a.txt | tr '\n' ' '
1,2,3 4,5,6 1,2,3 4,5,6 1,2,3 4,5,6 1,2,3 4,5,6 1,2,3 4,5,6
注意tr最后那个参数是空格,否则会报错
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
我用shell从数据库的一张表中的一个字段查询出这样一个值(这是一个字符串):
T.ZWBGZDMC=S.ZWBGZDMC,\\nT.YWBGZDMC=S.YWBGZDMC,\\nT.ZDLX= S.ZDLX,\\nT.SJY=S.SJY,\\nT.GXBZ=S.GXBZ,\\nT.MRUT=S.MRUT,\\nT.XXLY=S.XXLY
但是我把这个字符串>>a.txt的时候,文本显示为:
T.ZWBGZDMC=S.ZWBGZDMC,\nT.YWBGZDMC=S.YWBGZDMC,\nT.ZDLX= S.ZDLX,\nT.SJY=S.SJY,\nT.GXBZ=S.GXBZ,\nT.MRUT=S.MRUT,\nT.XXLY=S.XXLY
而不是把\n解释为换行符,求解。我要做的就是在逗号后面换行的。
(一) 最近在学习shell编程,可是在《Linux程序设计》指定的网站上下载了源码,使用的时候却一直出问题。提示:”bash: ./here1:/bin/sh^M:损坏的解释器: 没有该文件或目录“。之后用vi编辑器打开文件,发觉每一行的最后有浅蓝色的字符'^M'。才知道了问题所在 其实并没什么奇怪的,出现这种错误的原因是因为Linux和Windows文本文件的行结束标志不同。在Linux中,文本文件用"\n"(0a)表示回车换行,而Windows用"\r\n"(0d 0a)表示回车换行。所以在Linux中使用Windows的文本文件常常会出现错误。为了避免这种错误,Linux提供了两种文本格式相互转化的命令:dos2unix和unix2dos,dos2unix把"\r\n"转化成"\n",unixtodos把"\n"转化成"\r\n"。 命令dos2unix和unix2dos的使用非常简单,格式为:dos2unix filename 如果想更多的了解这两个命令,可以查看手册: man dos2unix 它会告诉你dos2unix的高级用法 (二) Ubuntu下默认没有安装dos2unix工具,而且也没有一个叫这个名字的工具(我在solaris里用过dos2unix,不知道为啥Ubuntu没有)。但是有一个替代工具——tofrodos , 下面就说一下它的安装和使用。 当然还是apt安装啦。 (1)安装tofrodos sudo apt-get install tofrodos 实际上它安装了两个工具:todos(相当于unix2dos),和fromdos(相当于dos2unix) 安装完即可,现在你已经可以进行文本格式的转换啦。 比如: todos Hello.txt (即unix2dos Hello.txt) fromdos Hello.txt (即dos2unix Hello.txt) (2)做一些优化 由于习惯了unix2dos和dos2unix的命令,可以把上面安装的两个工具链接成unix2dos 和dos2unix,或者仅仅是起个别名,并放在启动脚本里。 步骤:以下是代码片段: ln -s /usr/bin/todos /usr/bin/unix2dos ln -s /usr/bin/fromdos /usr/bin/dos2unix 或者在 ~/.bashrc里起个别名 添加 alias unix2dos=todos alias dos2unix=fromdos (三) 另外如果要在目录中大量替换, 可以使用find + xargs 比如: find ./model -name *.sh | xargs fromdos
T.ZWBGZDMC=S.ZWBGZDMC,\\nT.YWBGZDMC=S.YWBGZDMC,\\nT.ZDLX= S.ZDLX,\\nT.SJY=S.SJY,\\nT.GXBZ=S.GXBZ,\\nT.MRUT=S.MRUT,\\nT.XXLY=S.XXLY
但是我把这个字符串>>a.txt的时候,文本显示为:
T.ZWBGZDMC=S.ZWBGZDMC,\nT.YWBGZDMC=S.YWBGZDMC,\nT.ZDLX= S.ZDLX,\nT.SJY=S.SJY,\nT.GXBZ=S.GXBZ,\nT.MRUT=S.MRUT,\nT.XXLY=S.XXLY
而不是把\n解释为换行符,求解。我要做的就是在逗号后面换行的。
(一) 最近在学习shell编程,可是在《Linux程序设计》指定的网站上下载了源码,使用的时候却一直出问题。提示:”bash: ./here1:/bin/sh^M:损坏的解释器: 没有该文件或目录“。之后用vi编辑器打开文件,发觉每一行的最后有浅蓝色的字符'^M'。才知道了问题所在 其实并没什么奇怪的,出现这种错误的原因是因为Linux和Windows文本文件的行结束标志不同。在Linux中,文本文件用"\n"(0a)表示回车换行,而Windows用"\r\n"(0d 0a)表示回车换行。所以在Linux中使用Windows的文本文件常常会出现错误。为了避免这种错误,Linux提供了两种文本格式相互转化的命令:dos2unix和unix2dos,dos2unix把"\r\n"转化成"\n",unixtodos把"\n"转化成"\r\n"。 命令dos2unix和unix2dos的使用非常简单,格式为:dos2unix filename 如果想更多的了解这两个命令,可以查看手册: man dos2unix 它会告诉你dos2unix的高级用法 (二) Ubuntu下默认没有安装dos2unix工具,而且也没有一个叫这个名字的工具(我在solaris里用过dos2unix,不知道为啥Ubuntu没有)。但是有一个替代工具——tofrodos , 下面就说一下它的安装和使用。 当然还是apt安装啦。 (1)安装tofrodos sudo apt-get install tofrodos 实际上它安装了两个工具:todos(相当于unix2dos),和fromdos(相当于dos2unix) 安装完即可,现在你已经可以进行文本格式的转换啦。 比如: todos Hello.txt (即unix2dos Hello.txt) fromdos Hello.txt (即dos2unix Hello.txt) (2)做一些优化 由于习惯了unix2dos和dos2unix的命令,可以把上面安装的两个工具链接成unix2dos 和dos2unix,或者仅仅是起个别名,并放在启动脚本里。 步骤:以下是代码片段: ln -s /usr/bin/todos /usr/bin/unix2dos ln -s /usr/bin/fromdos /usr/bin/dos2unix 或者在 ~/.bashrc里起个别名 添加 alias unix2dos=todos alias dos2unix=fromdos (三) 另外如果要在目录中大量替换, 可以使用find + xargs 比如: find ./model -name *.sh | xargs fromdos
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你知道Linux的换行符是什么就行了
sed应当可以 直接替换最后一行的\n
sed应当可以 直接替换最后一行的\n
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
dos2unix file(文件名)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询