पायथन डेटा पर्सिस्टेंस - अचार मॉड्यूल

क्रमबद्धता और विलवणीकरण के लिए पायथन की शब्दावली क्रमशः अचार और अनप्लिकिंग है। पायथन लाइब्रेरी में अचार मॉड्यूल, बहुत पायथन विशिष्ट डेटा प्रारूप का उपयोग करता है। इसलिए, गैर-पायथन एप्लिकेशन ठीक से पिक किए गए डेटा को डीरिएलाइज करने में सक्षम नहीं हो सकते हैं। यह भी सलाह दी जाती है कि वे गैर-प्रमाणित स्रोत से डेटा को अनपिक न करें।

क्रमबद्ध (पिक) डेटा बाइट स्ट्रिंग या बाइनरी फ़ाइल में संग्रहीत किया जा सकता है। यह मॉड्यूल परिभाषित करता हैdumps() तथा loads()बाइट स्ट्रिंग का उपयोग करके डेटा को अचार और अनपिक करने के लिए कार्य करता है। फ़ाइल आधारित प्रक्रिया के लिए, मॉड्यूल में हैdump() तथा load() समारोह।

पायथन के अचार प्रोटोकॉल बाइनरी डेटा से / से पायथन ऑब्जेक्ट्स के निर्माण और डिकॉन्स्ट्रक्टिंग में उपयोग किए जाने वाले कन्वेंशन हैं। वर्तमान में, अचार मॉड्यूल नीचे सूचीबद्ध के रूप में 5 अलग-अलग प्रोटोकॉल को परिभाषित करता है -

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

Protocol version 0

मूल "मानव पठनीय" प्रोटोकॉल पिछले संस्करणों के साथ पीछे की ओर संगत है।

2

Protocol version 1

पुराने बाइनरी प्रारूप भी पायथन के पुराने संस्करणों के साथ संगत हैं।

3

Protocol version 2

पाइथन 2.3 में पेश नई शैली की कक्षाओं के कुशल अचार प्रदान करता है।

4

Protocol version 3

पायथन 3.0 में जोड़ा गया। अनुशंसित जब अन्य पायथन 3 संस्करणों के साथ संगतता आवश्यक है।

5

Protocol version 4

पायथन 3.4 में जोड़ा गया था। यह बहुत बड़ी वस्तुओं के लिए समर्थन जोड़ता है

उदाहरण

अचार मॉड्यूल में डंप () फ़ंक्शन होता है, जो कि अचार डेटा का एक स्ट्रिंग प्रतिनिधित्व देता है।

from pickle import dump
dct={"name":"Ravi", "age":23, "Gender":"M","marks":75}
dctstring=dumps(dct)
print (dctstring)

उत्पादन

b'\x80\x03}q\x00(X\x04\x00\x00\x00nameq\x01X\x04\x00\x00\x00Raviq\x02X\x03\x00\x00\x00ageq\x03K\x17X\x06\x00\x00\x00Genderq\x04X\x01\x00\x00\x00Mq\x05X\x05\x00\x00\x00marksq\x06KKu.

उदाहरण

लोड का उपयोग करें () फ़ंक्शन, स्ट्रिंग को अनपिक करने और मूल शब्दकोश ऑब्जेक्ट प्राप्त करने के लिए।

from pickle import load
dct=loads(dctstring)
print (dct)

उत्पादन

{'name': 'Ravi', 'age': 23, 'Gender': 'M', 'marks': 75}

डंप () फ़ंक्शन का उपयोग करके और लोड () फ़ंक्शन का उपयोग करके प्राप्त ऑब्जेक्ट्स को डिस्क फ़ाइल में लगातार संग्रहीत किया जा सकता है।

import pickle
f=open("data.txt","wb")
dct={"name":"Ravi", "age":23, "Gender":"M","marks":75}
pickle.dump(dct,f)
f.close()

#to read
import pickle
f=open("data.txt","rb")
d=pickle.load(f)
print (d)
f.close()

अचार मॉड्यूल भी प्रदान करता है, के रूप में क्रमांकन तंत्र के लिए वस्तु उन्मुख एपीआई Pickler तथा Unpickler कक्षाएं।

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

class User:
   def __init__(self,name, mob):
      self.name=name
      self.mobile=mob
   def __str__(self):
return ('Name: {} mobile: {} '. format(self.name, self.mobile))

किसी फ़ाइल में उपरोक्त वर्ग के ऑब्जेक्ट को चुनने के लिए हम पिकलर क्लास और उसके डंप () विधि का उपयोग करते हैं।

from pickle import Pickler
user1=User('Rajani', '[email protected]', '1234567890')
file=open('userdata','wb')
Pickler(file).dump(user1)
Pickler(file).dump(user2)
file.close()

इसके विपरीत, Unpickler वर्ग में क्रमबद्ध वस्तु को पुनः प्राप्त करने के लिए लोड () विधि है: -

from pickle import Unpickler
file=open('usersdata','rb')
user1=Unpickler(file).load()
print (user1)