這篇文章主要介紹了python中如何解決serial與stm32通信的編碼問(wèn)題,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
為廣河等地區(qū)用戶提供了全套網(wǎng)頁(yè)設(shè)計(jì)制作服務(wù),及廣河網(wǎng)站建設(shè)行業(yè)解決方案。主營(yíng)業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、廣河網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠(chéng)的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長(zhǎng)期合作。這樣,我們也可以走得更遠(yuǎn)!使用環(huán)境:
ubuntu18.04
python3.65
問(wèn)題點(diǎn):
使用pyserial與stm32通信,使用如下形式的編碼進(jìn)行write
(input_s + '\r\n').encode('utf-8')
但是在接受stm的信息的時(shí)候使用'utf-8'解碼會(huì)出現(xiàn)亂碼問(wèn)題
在查了可用編碼后,發(fā)現(xiàn)可能是中文無(wú)法解碼的問(wèn)題,使用'gbk'--統(tǒng)一漢語(yǔ)進(jìn)行解碼,可以解決亂碼問(wèn)題。
utf-8雖然是通用語(yǔ)言編碼標(biāo)準(zhǔn),但中文出現(xiàn)亂碼可以使用有針對(duì)性的'gbk'進(jìn)行解碼。
除此之外,python官方也有一種解決辦法:
bytearray.decode(encoding="utf-8", errors="strict")
返回從給定 bytes 解碼出來(lái)的字符串。 默認(rèn)編碼為 'utf-8'。 可以給出 errors 來(lái)設(shè)置不同的錯(cuò)誤處理方案。 errors 的默認(rèn)值為 'strict',表示編碼錯(cuò)誤會(huì)引發(fā) UnicodeError。 其他可用的值為 'ignore', 'replace' 以及任何其他通過(guò) codecs.register_error() 注冊(cè)的名稱,請(qǐng)參閱 錯(cuò)誤處理方案 小節(jié)。 要查看可用的編碼列表,請(qǐng)參閱 標(biāo)準(zhǔn)編碼 小節(jié)。
我們可以看到把errors關(guān)鍵字設(shè)置為ignore也可以解決編碼問(wèn)題。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“python中如何解決serial與stm32通信的編碼問(wèn)題”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!