पायथन डेटा पर्सिस्टेंस - ऑब्जेक्ट सीरियलाइज़ेशन

पायथन के बिल्ट-इन ओपन () फंक्शन द्वारा लौटाए गए पायथन की फाइल में एक महत्वपूर्ण कमी है। जब 'डब्ल्यू' मोड के साथ खोला जाता है, तो लेखन () विधि केवल स्ट्रिंग ऑब्जेक्ट को स्वीकार करती है।

इसका मतलब है, यदि आपके पास किसी भी गैर-स्ट्रिंग रूप में दर्शाया गया डेटा है, तो निर्मित कक्षाओं (संख्या, शब्दकोश, सूची या ट्यूपल्स) या अन्य उपयोगकर्ता-परिभाषित कक्षाओं में या तो वस्तु, इसे सीधे फाइल करने के लिए नहीं लिखा जा सकता है। लिखने से पहले, आपको इसे इसके स्ट्रिंग प्रतिनिधित्व में बदलने की आवश्यकता है।

numbers=[10,20,30,40]
   file=open('numbers.txt','w')
   file.write(str(numbers))
   file.close()

एक द्विआधारी फ़ाइल के लिए, के लिए तर्क write()विधि एक बाइट ऑब्जेक्ट होना चाहिए। उदाहरण के लिए, पूर्णांकों की सूची को बाइट्स द्वारा परिवर्तित किया जाता हैbytearray() फ़ंक्शन और फिर फाइल करने के लिए लिखा गया।

numbers=[10,20,30,40]
   data=bytearray(numbers)
   file.write(data)
   file.close()

संबंधित डेटा प्रकार में फ़ाइल से डेटा वापस पढ़ने के लिए, रिवर्स रूपांतरण करना होगा।

file=open('numbers.txt','rb')
   data=file.read()
   print (list(data))

इस प्रकार का मैनुअल रूपांतरण, स्ट्रिंग या बाइट फॉर्मेट (और इसके विपरीत) के ऑब्जेक्ट के लिए बहुत ही बोझिल और थकाऊ है। एक बाइट स्ट्रीम के रूप में एक पायथन ऑब्जेक्ट की स्थिति को सीधे फ़ाइल, या मेमोरी स्ट्रीम में संग्रहीत करना और इसकी मूल स्थिति को पुनः प्राप्त करना संभव है। इस प्रक्रिया को सीरियलाइजेशन और डी-सीरियलाइजेशन कहा जाता है।

पाइथन के पुस्तकालय में निर्मित में क्रमांकन और डीरियलाइज़ेशन प्रक्रिया के लिए विभिन्न मॉड्यूल शामिल हैं।

अनु क्रमांक। नाम और विवरण
1

pickle

पायथन विशिष्ट क्रमांकन पुस्तकालय

2

marshal

पुस्तकालय आंतरिक रूप से क्रमांकन के लिए उपयोग किया जाता है

3

shelve

पाइथोनिक ऑब्जेक्ट दृढ़ता

4

dbm

पुस्तकालय यूनिक्स डेटाबेस के लिए इंटरफ़ेस की पेशकश

5

csv

सीएसवी प्रारूप के लिए पायथन डेटा के भंडारण और पुनर्प्राप्ति के लिए पुस्तकालय

6

json

सार्वभौमिक JSON प्रारूप में क्रमांकन के लिए लाइब्रेरी