昨天寫一個腳本花了一天的2/3的時間,而且大部分時間都耗在了sed命令上,今天不總結一下都對不起昨天流逝的時間啊~~~
用sed命令在行首或行尾添加字符的命令有以下幾種:假設處理的文本為test.file在每行的頭添加字符,比如"HEAD",命令如下:sed 's/^/HEAD&/g' test.file在每行的行尾添加字符,比如“TAIL”,命令如下:sed 's/$/&TAIL/g' test.file運行結果如下圖:
幾點說明:1."^"代表行首,"
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符號,而這通常是看不出來的??梢杂?quot;cat -A test.file"命令查看。因此當我想在行尾添加字符的時候,它總是添加在行首且會覆蓋掉原來行首的字符。要把文件轉換一下,有兩種方法:1.命令dos2unix test.file2.去掉"/r" ,用命令sed -i 's//r//' test.file
好了,這樣處理完,就OK啦!??!
新聞熱點
疑難解答