1樓:多多來看看
1.s/.*(time.
*) ms/\1/,我想你不瞭解的主要是\1這個吧,我舉個例子,s/regexp/\1/,這句的意思就是用regexp中的第1個子表示式的內容來替換符合表示式regexp的內容。放在你這個例子中就是,s/.*(time.
*) ms/\1/,第1個正則中(time.*)是子表示式,第二個中的\1是指將滿足.*(time.
*) ms的內容替換為第1個子表示式(time.*),所以輸出為time=xx
2.s/.*time=//,要明白sed中如何替換文字的,s/regexp1/replacement/,是用replacement來替換regexp1表示式所匹配的內容,在你這個例子中要替換的表示式是/.
*time=/,替換的內容為空,//,所以實際的意思就是將/.*time=/匹配的內容刪除,輸出為xx ms
3.[0-9.]的意思是匹配數字0-9或.,+的意思是重複前一個匹配1次以上,整個的意思就是匹配連續的數字或點號
2樓:福星高照的大花
正規表示式寫得有點問題,第二個是因為沒有匹配的結果,在這種情況下sed預設列印出所有輸入。你加個 -n 選項就看不到輸出了。
之所以不能匹配,問題出在中間 \([^\(<\/span>\)]*\) 這部分。這個表示 非 <, /, s, p, a, n, > 這些字元,即中間不能出現這些字元中的任意一個,而非看作一個整體。
其實,中間只需要判斷 非 < 就行了,我改一下:
echo "abc5678"|sed 's/.*\([^<]*\)<\/span>.*/\1/'
這樣應該就可以了。
3樓:匿名使用者
sed "s#\/#\\\/#g" temp_scrtxt.txt
試試看如果還不行 你看看eval命令
sed如何將一個變數替換另一個變數
shell指令碼sed命令如何使用變數替換掉包含指定字串的整行
4樓:匿名使用者
#先將包含指定字串的整行列印到變數tmptmp=$(sed -n '/$/p' 文字名)#然後將文字中這一整行字串替換為你想要修改的字串sed -i 's/$/$/g' 文字名
5樓:匿名使用者
sed "s/zip/$zip/g" file
sed雙引號可以識別變數
linux 下用shell sed替換文字中的字串
6樓:匿名使用者
sed 'n;s/hour\n/hour/' tt.txt
7樓:心想卻不能
sed 's/hour\\n/hour/' tt.txt
在前面\n加個轉義字元\就可以了,這樣比較好理解
8樓:歐洲竹子
sed是行編輯器,用這個工具非常困難。可以參考以下指令碼:
#!/bin/bash
while read line
doif echo $line | grep 'hour$' >/dev/null; then
echo $line | tr -d '\n'
else
echo $line
fidone < $1
1,將上面指令碼儲存為****.sh
2,chmod 755 ****.sh
3,./****.sh file
用SHELL程式設計問題,如何判斷檔案型別
樓上說的對,你應該使用case語句 用shell程式設計問題,如何判斷檔案型別 bin sh x ls l awk y awk 給你寫這個是判斷目錄下所有檔案的型別 如何判斷檔案型別 linux shell問題 判斷檔案字尾 製作什麼 shell 啊 tar 本來就支援自動識別 root bizbo...
用bat做字元替換,bat替換指定行的內容中,指定的字串
你可以在乙個excel中,替換一遍,在替換前,開啟錄製巨集的功能。這樣就可以將要做的事全部錄下來,儲存下來。再用這個帶 巨集 的excel開啟另外一些excel檔案,執行巨集就成了。巨集錄製,在工具 巨集 錄製巨集 回答你補充的問題,因為沒看到你的原始檔案,不知它的結構是如何,如果沒有區別於其它的唯...
shell中和的主要區別是什麼,shell中的 和 是什麼意思,有什麼區別
實際上是bash 中 test 命令的簡寫。即所有的 expr 等於 test expr 對 test 命令來說,用 eq 要進行數字比較,而你此時傳入字串,就報錯了。expr 是bash中真正的條件判斷語句,其語法更符合程式設計習慣 比如 的用法 雖然我認為在 中 故意傳字串給 eq 也應該像 t...