用sed命令在行首或行尾添加字符的命令有如下幾種:mysql
假設處理的文本爲test.filelinux
在每行的頭添加字符,好比"HEAD",命令以下:sql
sed 's/^/HEAD/g' test.file數據庫
在每行的行尾添加字符,好比「TAIL」,命令以下:windows
sed 's/$/TAIL/g' test.fileunix
運行結果以下圖:test
幾點說明:sed
1."^"表明行首,"$"表明行尾file
2.'s/$/TAIL/g'中的字符g表明每行出現的字符所有替換,若是想在特定字符處添加,g就有用了,不然只會替換每行第一個,而不繼續日後找了方法
例:
3.若是想導出文件,在命令末尾加"> outfile_name";若是想在原文件上更改,添加選項"-i",如
4.也能夠把兩條命令和在一塊兒,在test.file的每一行的行頭和行尾分別添加字符"HEAD"、「TAIL」,命令:sed '/./{s/^/HEAD/;s/$/TAIL/}' test.file
以上其實都還OK,昨天花太多時間,主要由於被處理的文件是用mysql從數據庫提取的結果導出來的,別人給我以後我就直接處理,太腦殘了= -我一直有點懷疑之因此結果不對,有多是windows和linux換行的問題,但是由於對sed不熟,就一直在搞sed。。。。。。。
衆所周知(= -),window和linux的回車換行之云云,若是你知道了,跳過這一段,不知道,讀一下唄:
Unix系統裏,每行結尾只有「<換行>」,即「\n」;Windows系統裏面,每行結尾是「<換行><回 車>」,即「\n\r」。一個直接後果是,Unix系統下的文件在Windows裏打開的話,全部文字會變成一行;而Windows裏的文件在 Unix下打開的話,在每行的結尾可能會多出一個^M符號。
好了,因此個人問題就出在被處理的文件的每行末尾都有^M符號,而這一般是看不出來的。能夠用"cat -A test.file"命令查看。所以當我想在行尾添加字符的時候,它老是添加在行首且會覆蓋掉原來行首的字符。
要把文件轉換一下,有兩種方法:
1.命令dos2unix test.file
2.去掉"\r" ,用命令sed -i 's/\r//' test.file
好了,這樣處理完,就OK啦!!!