日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python3文件的编码类型是什么_python3.x - 怎么查看某个文件的编码方式?python

發布時間:2023/12/10 python 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python3文件的编码类型是什么_python3.x - 怎么查看某个文件的编码方式?python 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問 題

python的確很贊,但是編碼這個問題真的太尿性了。。。

現在我有一個文件,不論他的編碼方式是什么,我都想把它轉化成utf-8的格式。我的想法是先讀取文件內容,保存到data變量中去,然后再以utf-8的格式寫入文件。

但是現在遇到的問題是當我要打開某文件是得知道它的編碼格式是什么,不然就總是報錯,文件也打不開。

比如說我執行下面的代碼

with codecs.open("test.csv","r",encoding="utf-8") as f:

data = f.read()

print(data)

print(chardet.detect(data))

除非test.csv文件的確是以utf-8的格式編碼的才能正常打開,如果我用記事本修改成Unicode編碼,結果就會報錯,錯誤信息如下

UnicodeDecodeError: 'utf-8' codec can't decode byte 0xff in position 0: invalid start byte

所以想問一下有沒有什么辦法可以知道整個文件的編碼方式,最好是不用讀寫操作,或者直接給一個庫函數。

我有試過用chardet.detect()查看文件編碼格式,但是總是報錯。錯誤信息如下

Traceback (most recent call last):

File "E:\Code\python\Flask\csv-mysql\test.py", line 44, in

print(chardet.detect(data))

File "C:\Python35\lib\site-packages\chardet\__init__.py", line 25, in detect

raise ValueError('Expected a bytes object, not a unicode object')

ValueError: Expected a bytes object, not a unicode object

解決方案

with open("test.csv","rb") as f:

data = f.read()

print(chardet.detect(data))

用二進制模式讀取

掃一掃關注IT屋

微信公眾號搜索 “ IT屋 ” ,選擇關注與百萬開發者在一起

總結

以上是生活随笔為你收集整理的python3文件的编码类型是什么_python3.x - 怎么查看某个文件的编码方式?python的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。