পিক.ডম্প ব্যবহার করে - TypeError: অবশ্যই স্ট্রাইট হতে হবে, বাইট নয়


242

আমি পাইথন ৩.৩ ব্যবহার করছি এবং একটি সাধারণ অভিধান বাছাই করার সময় আমার একটি ক্রিপ্টিক ত্রুটি হচ্ছে having

কোডটি এখানে:

import os
import pickle
from pickle import *
os.chdir('c:/Python26/progfiles/')

def storvars(vdict):      
    f = open('varstor.txt','w')
    pickle.dump(vdict,f,)
    f.close()
    return

mydict = {'name':'john','gender':'male','age':'45'}
storvars(mydict)

এবং আমি পেয়েছি:

Traceback (most recent call last):
  File "C:/Python26/test18.py", line 31, in <module>
    storvars(mydict)
  File "C:/Python26/test18.py", line 14, in storvars
    pickle.dump(vdict,f,)
TypeError: must be str, not bytes

উত্তর:


404

আউটপুট ফাইলটি বাইনারি মোডে খোলার প্রয়োজন:

f = open('varstor.txt','w')

করা প্রয়োজন:

f = open('varstor.txt','wb')

22
ঠিক একই সমস্যায় পড়ার পরে , আমি দেখেছিলাম যেখানে "বাইনারি" পড়ার / লেখার প্রয়োজনীয়তার কথা ডক্সেpickle.dump() এবং এর জন্য উল্লেখ করা হয়েছিল pickle.load()। উভয় জায়গাতেই এটি শুধুমাত্র ফাংশন ব্যাখ্যার মাঝখানে কাছে যাওয়ার সময় উল্লেখ করা হয়েছিল। কারও এই পরিষ্কার করা উচিত।
ম্যাথু

9
আমি পাইথন প্রকল্পের সাথে # 24159 দায়ের করেছি । সম্ভবত কিছু আছে যা এই এবং অনুরূপ পরিস্থিতিতে অভিজ্ঞতার উন্নতির জন্য করা যেতে পারে।
জেসন আর। কুমবস

1
এই নিবন্ধটিতে ডাব্লুবি মোড ব্যবহার করে উল্লেখ করা হয়নি এবং এটি অনুসন্ধানের ফলাফলের শীর্ষে প্রদর্শিত হয় এবং এটি 2019 সালে লেখা হয়েছিল: চিন্তাচূত
পিক্লে-

22

ঠিক একই সমস্যা ছিল। পাইথন 3-তে, বাইনারি মোডগুলি 'wb', 'rb' নির্দিষ্ট করা আবশ্যক যেখানে পাইথন 2x এ তাদের প্রয়োজন হয় না। আপনি যখন পাইথন 2x ভিত্তিক টিউটোরিয়ালগুলি অনুসরণ করেন, সে কারণেই আপনি এখানে আছেন।

import pickle

class MyUser(object):
    def __init__(self,name):
        self.name = name

user = MyUser('Peter')

print("Before serialization: ")
print(user.name)
print("------------")
serialized = pickle.dumps(user)
filename = 'serialized.native'

with open(filename,'wb') as file_object:
    file_object.write(serialized)

with open(filename,'rb') as file_object:
    raw_data = file_object.read()

deserialized = pickle.loads(raw_data)


print("Loading from serialized file: ")
user2 = deserialized
print(user2.name)
print("------------")
আমাদের সাইট ব্যবহার করে, আপনি স্বীকার করেছেন যে আপনি আমাদের কুকি নীতি এবং গোপনীয়তা নীতিটি পড়েছেন এবং বুঝতে পেরেছেন ।
Licensed under cc by-sa 3.0 with attribution required.