解決Python 寫文件報(bào)錯(cuò)TypeError的問題
處理上傳的文件:
f1 = request.FILES[’pic’] fname = ’%s/%s’ % (settings.MEDIA_ROOT, f1.name) with open(fname, ’w’) as pic: for c in f1.chunks(): pic.write(c)
測試報(bào)錯(cuò):
TypeError at /upload/
write() argument must be str, not bytes
把之前的打開語句修改為用二進(jìn)制方式打開:
f1 = request.FILES[’pic’] fname = ’%s/%s’ % (settings.MEDIA_ROOT, f1.name) with open(fname, ’wb+’) as pic: for c in f1.chunks(): pic.write(c)
沒有問題了~
補(bǔ)充知識(shí):python3使用pickle讀取文件提示TypeError或者UnicodeDecodeError的解決辦法
python的pickle模塊實(shí)現(xiàn)了基本的數(shù)據(jù)序列和反序列化。通過pickle模塊的序列化操作我們能夠?qū)⒊绦蛑羞\(yùn)行的對象信息保存到文件中去,永久存儲(chǔ);通過pickle模塊的反序列化操作,我們能夠從文件中創(chuàng)建上一次程序保存的對象。
python2使用的是cPickle模塊,而在python3中cPickle已經(jīng)被取消,取而代之的是pickle模塊。
開發(fā)過程中,我曾經(jīng)遇到一個(gè)奇怪的問題,在讀取一個(gè)文件時(shí)候,使用python2的如下方式:
import cPickle
train, test, dicts = cPickle.load(open('./dataset/atis.pkl'))
是可以正常讀取文件的。
可是當(dāng)換做python3的方式讀取文件時(shí)候,如下:
import pickle
train, test, dicts = pickle.load(open('./dataset/atis.pkl'))
卻獲得了錯(cuò)誤提示,提示信息如下:
Traceback (most recent call last):
File “Main.py”, line 4, in
train, test, dicts = pickle.load(open(“./dataset/atis.pkl”))
TypeError: ‘str’ does not support the buffer interface
查詢錯(cuò)誤信息后得知解決辦法 鏈接,應(yīng)該指明用二進(jìn)制方式打開文件,于是代碼改為:
import pickle
train, test, dicts = pickle.load(open('./dataset/atis.pkl', 'rb'))
可是這時(shí)候錯(cuò)誤變成了:
Traceback (most recent call last):
File “Main.py”, line 4, in
train, test, dicts = pickle.load(open(“./dataset/atis.pkl”, “rb”))
UnicodeDecodeError: ‘a(chǎn)scii’ codec can’t decode byte 0xe8 in position 0: ordinal not in range(128)
于是再次求助萬能的google,終于找到了解決辦法 鏈接,我們需要告訴pickle:how to convert Python bytestring data to Python 3 strings,The default is to try and decode all string data as ASCII,所以代碼改為:
import pickle
train, test, dicts = pickle.load(open('./dataset/atis.pkl', 'rb'), encoding=’iso-8859-1’)
問題終于的到了解決。
以上這篇解決Python 寫文件報(bào)錯(cuò)TypeError的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))2. CSS清除浮動(dòng)方法匯總3. HTML DOM setInterval和clearInterval方法案例詳解4. HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)5. Vue如何使用ElementUI對表單元素進(jìn)行自定義校驗(yàn)及踩坑6. XML入門的常見問題(三)7. XML在語音合成中的應(yīng)用8. jscript與vbscript 操作XML元素屬性的代碼9. HTML5 Canvas繪制圖形從入門到精通10. 不要在HTML中濫用div
