पायथन डेटा पर्सिस्टेंस - ऑब्जेक्ट सीरियलाइज़ेशन
पायथन के बिल्ट-इन ओपन () फंक्शन द्वारा लौटाए गए पायथन की फाइल में एक महत्वपूर्ण कमी है। जब 'डब्ल्यू' मोड के साथ खोला जाता है, तो लेखन () विधि केवल स्ट्रिंग ऑब्जेक्ट को स्वीकार करती है।
इसका मतलब है, यदि आपके पास किसी भी गैर-स्ट्रिंग रूप में दर्शाया गया डेटा है, तो निर्मित कक्षाओं (संख्या, शब्दकोश, सूची या ट्यूपल्स) या अन्य उपयोगकर्ता-परिभाषित कक्षाओं में या तो वस्तु, इसे सीधे फाइल करने के लिए नहीं लिखा जा सकता है। लिखने से पहले, आपको इसे इसके स्ट्रिंग प्रतिनिधित्व में बदलने की आवश्यकता है।
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 प्रारूप में क्रमांकन के लिए लाइब्रेरी |