[問題] 新手擷取comport output問題
各位前輩好,
小弟目前在樹莓派上透過picocom得到comport output
目的是將每一筆output加上timestamp後存出log檔並且即時顯示在terminal
command如下:
sudo picocom /dev/xxxxxxxx -b 115200 -l |ts '%Y-%m-%d %H:%M:%.S' |tee xxx.log
由於某些原因log的換行符號摻雜了CR, LF, CRLF三種...
但後續的log分析在windows OS,導致換行整個大亂
目前的想法是希望能夠透過修改以上command將CR給濾掉,只保留LF及CRLF
已經嘗試過以下方式:
1. picocom本身的map參數將CR轉換為CRLF,但是會導致原本的CRLF變成CRLFLF
2. sed,有成功使用sed過濾掉,但是只能使用在文檔
配合picocom做即時過濾好像有困難,沒有找到相關的方法
卡關有點久,希望有前輩能夠提點一下,非常感謝!!
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 42.73.133.113 (臺灣)
※ 文章網址: https://www.ptt.cc/bbs/Linux/M.1590027839.A.0CC.html
→
05/21 11:04,
4年前
, 1F
05/21 11:04, 1F
→
05/21 11:04,
4年前
, 2F
05/21 11:04, 2F
→
05/21 11:06,
4年前
, 3F
05/21 11:06, 3F
windows那邊是可以改的,但因為還是會有查看raw log的需求,所以希望能夠從源頭下手
確實可以用sed先跑一下就達到目的
只是想求解否有辦法能夠做到從comport拿回來的同時可以把東西給過濾掉
這樣比較有利於後續的人員處理進一步的資料...感謝您的意見!
※ 編輯: Whisky (42.73.133.113 臺灣), 05/21/2020 11:13:29
→
05/21 11:08,
4年前
, 4F
05/21 11:08, 4F
推
05/21 11:13,
4年前
, 5F
05/21 11:13, 5F
有試過這樣的方式:
前略 |ts '%Y-%m-%d %H:%M:%.S' |sed -i 's/\r//g' |tee xxx.log
但是顯示write to stdout failed Broken pipe
還請各位解答一下...謝謝!
※ 編輯: Whisky (42.73.133.113 臺灣), 05/21/2020 11:18:30
→
05/21 11:26,
4年前
, 6F
05/21 11:26, 6F
-i拿掉後有成功!
感謝前輩們的幫忙!
※ 編輯: Whisky (42.73.133.113 臺灣), 05/21/2020 11:31:34
Linux 近期熱門文章
23
129
PTT數位生活區 即時熱門文章