Python中import模塊時報SyntaxError: (unicode error)'utf-8' codec can't decode 錯誤的解決辦法


老猿有個通過UE編輯(其他文本編輯器一樣有類似問題)的bmi.py文件,在Python Idle環境打開文件執行時沒有問題,但import時報錯:
SyntaxError: (unicode error) ‘utf-8’ codec can’t decode byte 0xc7 in position 0: invalid continuation byte,具體報錯截圖如下:
在這里插入圖片描述
老猿知道這是字符集編碼的問題,應該是Python import文件是支持UTF-8編碼,而老猿存儲時是GBK的編碼導致,怎么解決該問題呢?有以下三種辦法:
1、文件存儲時以UTF-8編碼存儲,每個編輯器應該都可以設置文件存儲的編碼格式,老猿的編輯器是UE,相關格式設置界面請見下面截圖:
在這里插入圖片描述

再將文件另存一下就可以了。

方法二,使用IDLE打開文件再進行格式轉換
使用IDLE打開非UTF-8編碼的文件時,系統會有如下提示信息:
在這里插入圖片描述
此時只要輸入正確編碼(Python默認會根據操作系統的設置給出一個默認值),如中文選擇cp936(具體字符集和代碼也的映射關系請見《轉:使用DOS命令chcp查看windows操作系統的默認編碼以及編碼和語言的對應關系》)。
打開成功后將文件再保存一下就可以將格式修改為Python可以正確解碼的格式了。

方法三,直接在文件中給出文件本身的編碼格式就可以了,如果是中文編碼的,可以在首行添加:

#-*-coding: GBK -*-

就可以正常識別了。

老猿Python,跟老猿學Python!
博客地址:https://blog.csdn.net/LaoYuanPython

請大家多多支持,點贊、評論和加關注!謝謝!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM