[問題] 新手擷取comport output問題

看板Linux作者 (AnAn Ni Hao)時間4年前 (2020/05/21 10:23), 4年前編輯推噓1(105)
留言6則, 2人參與, 4年前最新討論串1/1
各位前輩好, 小弟目前在樹莓派上透過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
windows分析程式不能改嗎? 應該蠻簡單的. 或者先跑一個
05/21 11:04, 1F

05/21 11:04, 4年前 , 2F
filter程式,再丟給原分析程式也可以
05/21 11:04, 2F

05/21 11:06, 4年前 , 3F
以你的第2點來說,在windows分析前用sed跑一下不就解決了?
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
如果是要全自動,那就是把sed放在ts和tee之間不就是了嗎?
05/21 11:08, 4F

05/21 11:13, 4年前 , 5F
同上,sed是吃STDIN的,可以放在pipeline
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
-i 參數是拿來改檔案的,把它拿掉
05/21 11:26, 6F
-i拿掉後有成功! 感謝前輩們的幫忙! ※ 編輯: Whisky (42.73.133.113 臺灣), 05/21/2020 11:31:34
文章代碼(AID): #1UnUO_3C (Linux)
文章代碼(AID): #1UnUO_3C (Linux)