पायथन डेटा पर्सिस्टेंस - क्विक गाइड
अजगर का अवलोकन - डेटा की दृढ़ता
किसी भी सॉफ्टवेयर एप्लिकेशन का उपयोग करने के दौरान, उपयोगकर्ता संसाधित होने के लिए कुछ डेटा प्रदान करता है। मानक इनपुट डिवाइस (कीबोर्ड) या अन्य डिवाइस जैसे डिस्क फ़ाइल, स्कैनर, कैमरा, नेटवर्क केबल, वाईफाई कनेक्शन, आदि का उपयोग करके डेटा इनपुट हो सकता है।
ऐसा डेटा प्राप्त किया जाता है, जिसे कंप्यूटर की मुख्य मेमोरी (RAM) में विभिन्न डेटा संरचनाओं जैसे कि, चर और ऑब्जेक्ट्स के रूप में संग्रहीत किया जाता है जब तक कि एप्लिकेशन चल रहा हो। इसके बाद, RAM से मेमोरी सामग्री मिट जाती है।
हालांकि, अधिक से अधिक बार, यह वांछित है कि चर और / या वस्तुओं के मूल्यों को इस तरह से संग्रहीत किया जाता है, कि जब भी आवश्यक हो, उसी डेटा को फिर से इनपुट करने के बजाय इसे पुनः प्राप्त किया जा सकता है।
शब्द 'दृढ़ता' का अर्थ है "इसके कारण को हटाने के बाद एक प्रभाव की निरंतरता"। डेटा की दृढ़ता का अर्थ है कि आवेदन समाप्त होने के बाद भी इसका अस्तित्व बना रहता है। इस प्रकार, गैर-वाष्पशील भंडारण माध्यम में संग्रहीत डेटा, जैसे, डिस्क फ़ाइल एक निरंतर डेटा संग्रहण है।
इस ट्यूटोरियल में, हम विभिन्न अंतर्निहित और तीसरे पक्ष के पायथन मॉड्यूल का पता लगाने के लिए डेटा को स्टोर करने और प्राप्त करने के लिए / जैसे टेक्स्ट फ़ाइल, सीएसवी, जेन्सन और एक्सएमएल फाइलों के साथ-साथ रिलेशनल और नॉन-रिलेशनल डेटाबेसों से प्राप्त करेंगे।
पायथन की अंतर्निहित फ़ाइल ऑब्जेक्ट का उपयोग करके, स्ट्रिंग डेटा को डिस्क फ़ाइल में लिखना और उससे पढ़ना संभव है। पायथन की मानक लाइब्रेरी, JSON और XML जैसी विभिन्न डेटा संरचनाओं में क्रमबद्ध डेटा को संग्रहीत और पुनर्प्राप्त करने के लिए मॉड्यूल प्रदान करती है।
पायथन का डीबी-एपीआई रिलेशनल डेटाबेस के साथ बातचीत करने का एक मानक तरीका प्रदान करता है। अन्य तीसरे पक्ष के पायथन पैकेज, एनओएसक्यूएल डेटाबेस जैसे कि मोंगोडीबी और कैसेंड्रा के साथ इंटरफेसिंग कार्यक्षमता को प्रस्तुत करते हैं।
यह ट्यूटोरियल ZODB डेटाबेस का भी परिचय देता है, जो पायथन ऑब्जेक्ट्स के लिए एक दृढ़ता एपीआई है। Microsoft Excel प्रारूप एक बहुत लोकप्रिय डेटा फ़ाइल स्वरूप है। इस ट्यूटोरियल में, हम सीखेंगे कि पायथन के माध्यम से .xlsx फाइल को कैसे संभाला जाए।
पाइथन बिल्ट-इन का उपयोग करता है input() तथा print()मानक इनपुट / आउटपुट संचालन करने के लिए कार्य। इनपुट () फ़ंक्शन मानक इनपुट स्ट्रीम डिवाइस, अर्थात कीबोर्ड से बाइट्स को पढ़ता है।
print()दूसरी ओर कार्य, मानक आउटपुट स्ट्रीम डिवाइस यानी डिस्प्ले मॉनिटर की ओर डेटा भेजता है। पायथन प्रोग्राम इन IO उपकरणों के साथ मानक स्ट्रीम ऑब्जेक्ट के माध्यम से इंटरैक्ट करता हैstdin तथा stdout sys मॉड्यूल में परिभाषित।
input()फ़ंक्शन वास्तव में sys.stdin ऑब्जेक्ट की रीडलाइन () विधि के आसपास एक आवरण है। इनपुट स्ट्रीम से सभी कीस्ट्रोक्स तब तक प्राप्त किए जाते हैं जब तक कि 'एंटर' कुंजी दबा दी जाती है।
>>> import sys
>>> x=sys.stdin.readline()
Welcome to TutorialsPoint
>>> x
'Welcome to TutorialsPoint\n'
ध्यान दें कि, readline()फ़ंक्शन एक अनुगामी '\ n' वर्ण छोड़ता है। एक रीड () विधि भी है जो मानक इनपुट स्ट्रीम से डेटा को तब तक पढ़ती है जब तक यह समाप्त नहीं हो जाताCtrl+D चरित्र।
>>> x=sys.stdin.read()
Hello
Welcome to TutorialsPoint
>>> x
'Hello\nWelcome to TutorialsPoint\n'
इसी तरह, print() स्टडआउट ऑब्जेक्ट का लेखन () विधि का अनुकरण करने वाला एक सुविधा कार्य है।
>>> x='Welcome to TutorialsPoint\n'
>>> sys.stdout.write(x)
Welcome to TutorialsPoint
26
बस स्टड और स्टडआउट पूर्वनिर्धारित स्ट्रीम ऑब्जेक्ट के रूप में, पायथन प्रोग्राम डिस्क फ़ाइल या नेटवर्क सॉकेट से डेटा पढ़ सकता है और भेज सकता है। वे भी धाराएँ हैं। कोई भी वस्तु जो पढ़ी है () विधि एक इनपुट स्ट्रीम है। कोई भी वस्तु जिसमें लेखन है () विधि एक आउटपुट स्ट्रीम है। स्ट्रीम के साथ संचार स्थापित ऑब्जेक्ट के संदर्भ में अंतर्निहित ओपन () फ़ंक्शन के साथ प्राप्त करके स्थापित किया जाता है।
खुला () फ़ंक्शन
यह अंतर्निहित फ़ंक्शन निम्न तर्कों का उपयोग करता है -
f=open(name, mode, buffering)
नाम पैरामीटर, डिस्क फ़ाइल या बाइट स्ट्रिंग का नाम है, प्रदर्शन के प्रकार (रीड, राइट, अपेंड आदि) को निर्दिष्ट करने के लिए मोड वैकल्पिक एक-वर्ण स्ट्रिंग है और बफरिंग पैरामीटर या तो 0, 1 या -1 है। बफ़रिंग बंद या चालू है।
फ़ाइल खोलने का तरीका नीचे दी गई तालिका के अनुसार गणना की गई है। डिफ़ॉल्ट मोड 'r' है
अनु क्रमांक | पैरामीटर और विवरण |
---|---|
1 | R पढ़ने के लिए खोलें (डिफ़ॉल्ट) |
2 | W लिखने के लिए खोलें, फ़ाइल को पहले काट-छाँट करें |
3 | X एक नई फ़ाइल बनाएं और उसे लिखने के लिए खोलें |
4 | A लेखन के लिए खुला है, अगर यह मौजूद है तो फ़ाइल के अंत में संलग्न है |
5 | B बाइनरी मोड |
6 | T पाठ मोड (डिफ़ॉल्ट) |
7 | + अद्यतन (पढ़ने और लिखने) के लिए एक डिस्क फ़ाइल खोलें |
फ़ाइल को सहेजने के लिए इसे 'w' मोड के साथ खोला जाना चाहिए।
f=open('test.txt','w')
यह फ़ाइल ऑब्जेक्ट आउटपुट स्ट्रीम के रूप में कार्य करता है, और इसमें लिखने () विधि तक पहुंच होती है। लेखन () विधि इस ऑब्जेक्ट को एक स्ट्रिंग भेजती है, और इसे अंतर्निहित फ़ाइल में संग्रहीत किया जाता है।
string="Hello TutorialsPoint\n"
f.write(string)
धारा को बंद करना महत्वपूर्ण है, यह सुनिश्चित करने के लिए कि बफर में शेष कोई भी डेटा पूरी तरह से इसे स्थानांतरित कर दिया गया है।
file.close()
कोशिश करें और फ़ाइल के सफल निर्माण की पुष्टि करने के लिए किसी भी परीक्षण संपादक (जैसे नोटपैड) का उपयोग करके 'test.txt' खोलें।
'Test.txt' की सामग्री को प्रोग्रामिक रूप से पढ़ने के लिए, इसे 'r' मोड में खोलना होगा।
f=open('test.txt','r')
यह ऑब्जेक्ट एक इनपुट स्ट्रीम के रूप में व्यवहार करता है। पायथन का उपयोग करके धारा से डेटा प्राप्त कर सकते हैंread() तरीका।
string=f.read()
print (string)
फ़ाइल की सामग्री पायथन कंसोल पर प्रदर्शित होती है। फ़ाइल ऑब्जेक्ट भी समर्थन करता हैreadline() वह विधि जो स्ट्रिंग को पढ़ने में सक्षम है जब तक कि यह ईओएफ चरित्र का सामना नहीं करती है।
हालाँकि, यदि उसी फ़ाइल को अतिरिक्त पाठ को संग्रहीत करने के लिए 'w' मोड में खोला जाता है, तो पहले की सामग्री मिट जाती है। जब भी, एक फाइल को लिखित अनुमति के साथ खोला जाता है, तो यह माना जाता है कि यह एक नई फाइल है। मौजूदा फ़ाइल में डेटा जोड़ने के लिए, एपेंड मोड के लिए 'a' का उपयोग करें।
f=open('test.txt','a')
f.write('Python Tutorials\n')
अब फ़ाइल में पहले के साथ-साथ नए जोड़े गए स्ट्रिंग हैं। फ़ाइल ऑब्जेक्ट भी समर्थन करता हैwritelines() फ़ाइल की सूची ऑब्जेक्ट में प्रत्येक स्ट्रिंग लिखने की विधि।
f=open('test.txt','a')
lines=['Java Tutorials\n', 'DBMS tutorials\n', 'Mobile development tutorials\n']
f.writelines(lines)
f.close()
उदाहरण
readlines()विधि स्ट्रिंग की एक सूची देता है, प्रत्येक फ़ाइल में एक लाइन का प्रतिनिधित्व करता है। फ़ाइल के अंत तक फ़ाइल लाइन को लाइन से पढ़ना भी संभव है।
f=open('test.txt','r')
while True:
line=f.readline()
if line=='' : break
print (line, end='')
f.close()
उत्पादन
Hello TutorialsPoint
Python Tutorials
Java Tutorials
DBMS tutorials
Mobile development tutorials
बाइनरी मोड
डिफ़ॉल्ट रूप से, फ़ाइल स्ट्रिंग पर रीड / राइट ऑपरेशन टेक्स्ट स्ट्रिंग डेटा पर किया जाता है। यदि हम मीडिया (एमपी 3), एक्जीक्यूटेबल्स (एक्सई), पिक्चर्स (जेपीजी) आदि जैसे विभिन्न प्रकार की फाइलों को संभालना चाहते हैं, तो हमें पढ़ने / लिखने के मोड में 'बी' उपसर्ग जोड़ना होगा।
निम्नलिखित कथन एक स्ट्रिंग को बाइट्स में बदल देगा और एक फाइल में लिख देगा।
f=open('test.bin', 'wb')
data=b"Hello World"
f.write(data)
f.close()
एन्कोड () फ़ंक्शन का उपयोग करके टेक्स्ट स्ट्रिंग को बाइट में बदलना भी संभव है।
data="Hello World".encode('utf-8')
हमें उपयोग करने की आवश्यकता है ‘rb’बाइनरी फ़ाइल पढ़ने के लिए मोड। रीड () विधि का लौटा मूल्य पहले मुद्रण से पहले डिकोड किया गया है।
f=open('test.bin', 'rb')
data=f.read()
print (data.decode(encoding='utf-8'))
बाइनरी फ़ाइल में पूर्णांक डेटा लिखने के लिए, पूर्णांक ऑब्जेक्ट को बाइट्स द्वारा परिवर्तित किया जाना चाहिए to_bytes() तरीका।
n=25
n.to_bytes(8,'big')
f=open('test.bin', 'wb')
data=n.to_bytes(8,'big')
f.write(data)
एक बाइनरी फ़ाइल से वापस पढ़ने के लिए, रीड () फ़ंक्शन को पूर्णांक से from_bytes () फ़ंक्शन में कनवर्ट करें।
f=open('test.bin', 'rb')
data=f.read()
n=int.from_bytes(data, 'big')
print (n)
फ्लोटिंग पॉइंट डेटा के लिए, हमें उपयोग करने की आवश्यकता है struct पायथन के मानक पुस्तकालय से मॉड्यूल।
import struct
x=23.50
data=struct.pack('f',x)
f=open('test.bin', 'wb')
f.write(data)
बाइनरी फ़ाइल से फ्लोट डेटा को पुनः प्राप्त करने के लिए रीड () फ़ंक्शन से स्ट्रिंग को अनपैक करना।
f=open('test.bin', 'rb')
data=f.read()
x=struct.unpack('f', data)
print (x)
एक साथ पढ़ने / लिखने
जब लिखने के लिए एक फ़ाइल खोली जाती है ('w' या 'a'), तो यह संभव नहीं है, इससे पढ़ें और इसके विपरीत। ऐसा करने से UnSupportedOperation त्रुटि होती है। हमें अन्य ऑपरेशन करने से पहले फ़ाइल को बंद करने की आवश्यकता है।
एक साथ दोनों ऑपरेशन करने के लिए, हमें मोड पैरामीटर में '+' वर्ण जोड़ना होगा। इसलिए, 'w +' या 'r +' मोड किसी फाइल को बंद किए बिना राइट () और साथ ही पढ़े () तरीकों का उपयोग करने में सक्षम बनाता है। फ़ाइल ऑब्जेक्ट किसी भी वांछित बाइट की स्थिति में स्ट्रीम को वापस लाने के लिए तलाश () फ़ंक्शन का भी समर्थन करता है।
f=open('test.txt','w+')
f.write('Hello world')
f.seek(0,0)
data=f.read()
print (data)
f.close()
निम्न तालिका ऑब्जेक्ट की तरह फ़ाइल के लिए उपलब्ध सभी विधियों को संक्षेप में प्रस्तुत करती है।
अनु क्रमांक | विधि और विवरण |
---|---|
1 | close() फ़ाइल बंद करता है। एक बंद फाइल को किसी भी अधिक पढ़ा या लिखा नहीं जा सकता है। |
2 | flush() आंतरिक बफर को फ्लश करें। |
3 | fileno() पूर्णांक फ़ाइल विवरणक लौटाता है। |
4 | next() हर बार फ़ाइल से अगली पंक्ति को लौटाया जा रहा है। पायथन 3 में अगला () पुनरावृत्त का उपयोग करें। |
5 | read([size]) फ़ाइल से अधिकांश आकार के बाइट्स पढ़ता है (यदि आकार बाइट प्राप्त करने से पहले ईओएफ हिट होता है तो कम)। |
6 | readline([size]) फ़ाइल से एक पूरी पंक्ति पढ़ता है। एक अनुगामी न्यूलाइन वर्ण स्ट्रिंग में रखा जाता है। |
7 | readlines([sizehint]) जब तक EOF रीडलाइन () का उपयोग करता है और एक सूची देता है जिसमें लाइनें होती हैं। |
8 | seek(offset[, whence]) फ़ाइल की वर्तमान स्थिति सेट करता है। 0-शुरू 1-वर्तमान 2-अंत। |
9 | seek(offset[, whence]) फ़ाइल की वर्तमान स्थिति सेट करता है। 0-शुरू 1-वर्तमान 2-अंत। |
10 | tell() फ़ाइल की वर्तमान स्थिति लौटाता है |
1 1 | truncate([size]) फ़ाइल के आकार को काटता है। |
12 | write(str) फ़ाइल के लिए एक स्ट्रिंग लिखता है। कोई रिटर्न वैल्यू नहीं है। |
फ़ाइल ऑब्जेक्ट के अलावा द्वारा लौटाया गया open()फ़ंक्शन, फ़ाइल IO संचालन भी पायथन के अंतर्निहित पुस्तकालय का उपयोग करके किया जा सकता है जिसमें ओएस मॉड्यूल है जो उपयोगी ऑपरेटिंग सिस्टम निर्भर कार्यों को प्रदान करता है। ये फ़ंक्शन फ़ाइल पर निम्न स्तर के रीड / राइट ऑपरेशन करते हैं।
open()ओएस मॉड्यूल से फ़ंक्शन अंतर्निहित खुले () के समान है। हालाँकि, यह एक फ़ाइल ऑब्जेक्ट नहीं लौटाता है लेकिन फ़ाइल डिस्क्रिप्टर, फ़ाइल खोलने के लिए एक विशिष्ट पूर्णांक है। फ़ाइल डिस्क्रिप्टर के मान 0, 1 और 2 स्टड, स्टडआउट और स्टडर स्ट्रीम का प्रतिनिधित्व करते हैं। अन्य फाइलों को 2 के बाद से वृद्धिशील फ़ाइल विवरणक दिया जाएगा।
के मामले में के रूप में open() अंतर्निहित कार्य, os.open()फ़ंक्शन को फ़ाइल एक्सेस मोड भी निर्दिष्ट करना होगा। ओएस मॉड्यूल में परिभाषित विभिन्न मोड के बाद तालिका।
अनु क्रमांक। | ओएस मॉड्यूल और विवरण |
---|---|
1 | os.O_RDONLY केवल पढ़ने के लिए खोलें |
2 | os.O_WRONLY केवल लिखने के लिए खोलें |
3 | os.O_RDWR पढ़ने और लिखने के लिए खुला |
4 | os.O_NONBLOCK खुले में शौच न करें |
5 | os.O_APPEND प्रत्येक लेखन पर संलग्न करें |
6 | os.O_CREAT यदि मौजूद नहीं है तो फ़ाइल बनाएँ |
7 | os.O_TRUNC टुकड़े टुकड़े का आकार ० |
8 | os.O_EXCL बनाने और फ़ाइल मौजूद होने पर त्रुटि |
इसमें डेटा लिखने के लिए एक नई फ़ाइल खोलने के लिए, निर्दिष्ट करें O_WRONLY साथ ही साथ O_CREATपाइप (!) ऑपरेटर डालने से मोड। Os.open () फ़ंक्शन फ़ाइल डिस्क्रिप्टर लौटाता है।
f=os.open("test.dat", os.O_WRONLY|os.O_CREAT)
ध्यान दें कि, डेटा को बाइट स्ट्रिंग के रूप में डिस्क फ़ाइल में लिखा जाता है। इसलिए, पहले की तरह एन्कोड () फ़ंक्शन का उपयोग करके एक सामान्य स्ट्रिंग को बाइट स्ट्रिंग में बदल दिया जाता है।
data="Hello World".encode('utf-8')
ओएस मॉड्यूल में लेखन () फ़ंक्शन इस बाइट स्ट्रिंग और फ़ाइल डिस्क्रिप्टर को स्वीकार करता है।
os.write(f,data)
बंद () फ़ंक्शन का उपयोग करके फ़ाइल को बंद करना न भूलें।
os.close(f)
Os.read () फ़ंक्शन का उपयोग करके किसी फ़ाइल की सामग्री को पढ़ने के लिए, निम्नलिखित कथनों का उपयोग करें:
f=os.open("test.dat", os.O_RDONLY)
data=os.read(f,20)
print (data.decode('utf-8'))
ध्यान दें कि, os.read () फ़ंक्शन को पढ़ने के लिए फ़ाइल डिस्क्रिप्टर और बाइट्स की संख्या की आवश्यकता होती है (बाइट स्ट्रिंग की लंबाई)।
यदि आप एक साथ पढ़ने / लिखने के संचालन के लिए एक फ़ाइल खोलना चाहते हैं, तो O_RDWR मोड का उपयोग करें। निम्न तालिका ओएस मॉड्यूल में महत्वपूर्ण फ़ाइल ऑपरेशन संबंधी कार्यों को दिखाती है।
अनु क्रमांक | कार्य और विवरण |
---|---|
1 | os.close(fd) फ़ाइल डिस्क्रिप्टर को बंद करें। |
2 | os.open(file, flags[, mode]) फ़ाइल खोलें और झंडे के अनुसार विभिन्न झंडे सेट करें और संभवतः मोड के अनुसार इसका मोड। |
3 | os.read(fd, n) फ़ाइल डिस्क्रिप्टर fd से अधिकांश n बाइट्स पर पढ़ें। एक स्ट्रिंग पढ़ें जिसमें बाइट्स पढ़ें। यदि fd द्वारा संदर्भित फ़ाइल का अंत पहुँच गया है, तो एक रिक्त स्ट्रिंग वापस आ जाती है। |
4 | os.write(fd, str) डिस्क्रिप्टर fd फ़ाइल करने के लिए स्ट्रिंग लिखें। वास्तव में लिखे गए बाइट्स की संख्या लौटाएं। |
पायथन के बिल्ट-इन ओपन () फंक्शन द्वारा लौटाए गए पायथन की फाइल में एक महत्वपूर्ण कमी है। जब 'डब्ल्यू' मोड के साथ खोला जाता है, तो लेखन () विधि केवल स्ट्रिंग ऑब्जेक्ट को स्वीकार करती है।
इसका मतलब है, यदि आपके पास किसी भी गैर-स्ट्रिंग रूप में दर्शाया गया डेटा है, तो निर्मित कक्षाओं (संख्या, शब्दकोश, सूची या ट्यूपल्स) या अन्य उपयोगकर्ता-परिभाषित कक्षाओं में या तो वस्तु, इसे सीधे फाइल करने के लिए नहीं लिखा जा सकता है। लिखने से पहले, आपको इसे इसके स्ट्रिंग प्रतिनिधित्व में बदलने की आवश्यकता है।
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 प्रारूप में क्रमांकन के लिए लाइब्रेरी |
क्रमबद्धता और विलवणीकरण के लिए पायथन की शब्दावली क्रमशः अचार और अनप्लिकिंग है। पायथन लाइब्रेरी में अचार मॉड्यूल, बहुत पायथन विशिष्ट डेटा प्रारूप का उपयोग करता है। इसलिए, गैर-पायथन एप्लिकेशन ठीक से पिक किए गए डेटा को डीरियलाइज़ करने में सक्षम नहीं हो सकते हैं। यह भी सलाह दी जाती है कि वे गैर-प्रमाणित स्रोत से डेटा को अनपिकल न करें।
क्रमबद्ध (पिक) डेटा बाइट स्ट्रिंग या बाइनरी फ़ाइल में संग्रहीत किया जा सकता है। यह मॉड्यूल परिभाषित करता है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)
पायथन के मानक पुस्तकालय में मार्शाल मॉड्यूल के ऑब्जेक्ट क्रमांकन विशेषताएं अचार मॉड्यूल के समान हैं। हालांकि, सामान्य प्रयोजन डेटा के लिए इस मॉड्यूल का उपयोग नहीं किया जाता है। दूसरी ओर, पायथन द्वारा इसका उपयोग पायथन मॉड्यूल (संकलित फ़ाइलों) के संकलित संस्करणों पर पढ़ने / लिखने के संचालन का समर्थन करने के लिए पायथन द्वारा आंतरिक वस्तु क्रमांकन के लिए किया जाता है।
मार्शल मॉड्यूल द्वारा उपयोग किया जाने वाला डेटा प्रारूप पायथन संस्करणों में संगत नहीं है। इसलिए, एक संस्करण का एक संकलित पायथन स्क्रिप्ट (.pyc फ़ाइल) संभवतः दूसरे पर निष्पादित नहीं होगी।
अचार मॉड्यूल की तरह, मार्शाल मॉड्यूल भी लोड () और डंप () में / से फ़ाइल में मार्शाल्ड ऑब्जेक्ट्स को पढ़ने और लिखने के लिए परिभाषित करता है।
डंप ()
यह फ़ंक्शन किसी फ़ाइल में समर्थित पायथन ऑब्जेक्ट का बाइट प्रतिनिधित्व लिखता है। फ़ाइल स्वयं एक बाइनरी फ़ाइल होती है जिसमें लिखित अनुमति होती है
भार()
यह फ़ंक्शन बाइट डेटा को बाइनरी फ़ाइल से पढ़ता है और इसे पायथन ऑब्जेक्ट में कनवर्ट करता है।
उदाहरण के बाद, पाइथन की कोड ऑब्जेक्ट्स को संभालने के लिए डंप () और लोड () फ़ंक्शंस का उपयोग किया जाता है, जो कि पहले से तैयार किए गए पायथन मॉड्यूल को स्टोर करने के लिए उपयोग किए जाते हैं।
कोड बिल्ट-इन का उपयोग करता है compile() एक स्रोत स्ट्रिंग से बाहर एक कोड ऑब्जेक्ट बनाने के लिए फ़ंक्शन जो पायथन निर्देशों को एम्बेड करता है।
compile(source, file, mode)
फ़ाइल पैरामीटर वह फ़ाइल होनी चाहिए जिसमें से कोड पढ़ा गया था। यदि यह किसी फ़ाइल से नहीं पढ़ा गया तो कोई भी मनमाना स्ट्रिंग पास नहीं होगा।
मोड पैरामीटर 'निष्पादन' है यदि स्रोत में कथनों का क्रम है, तो 'निष्कासित' यदि एक एकल अभिव्यक्ति है या 'एकल' है यदि इसमें एक एकल संवादात्मक कथन है।
संकलन कोड ऑब्जेक्ट तब डंप () फ़ंक्शन का उपयोग करके एक .pyc फ़ाइल में संग्रहीत किया जाता है।
import marshal
script = """
a=10
b=20
print ('addition=',a+b)
"""
code = compile(script, "script", "exec")
f=open("a.pyc","wb")
marshal.dump(code, f)
f.close()
Deserialize करने के लिए, .pyc फ़ाइल से ऑब्जेक्ट लोड () फ़ंक्शन का उपयोग करता है। चूंकि, यह एक कोड ऑब्जेक्ट देता है, इसे निष्पादन (), एक अन्य अंतर्निहित फ़ंक्शन का उपयोग करके चलाया जा सकता है।
import marshal
f=open("a.pyc","rb")
data=marshal.load(f)
exec (data)
पायथन के मानक पुस्तकालय में शेल्व मॉड्यूल सरल अभी तक प्रभावी वस्तु दृढ़ता तंत्र प्रदान करता है। इस मॉड्यूल में परिभाषित शेल्फ ऑब्जेक्ट डिक्शनरी जैसी वस्तु है जो लगातार एक डिस्क फ़ाइल में संग्रहीत होती है। यह सिस्टम की तरह UNIX पर dbm डेटाबेस के समान फाइल बनाता है।
शेल्फ शब्दकोश में कुछ प्रतिबंध हैं। केवल स्ट्रिंग डेटा प्रकार का उपयोग इस विशेष शब्दकोश ऑब्जेक्ट में कुंजी के रूप में किया जा सकता है, जबकि किसी भी पिकल योग्य पायथन ऑब्जेक्ट का उपयोग मूल्य के रूप में किया जा सकता है।
शेल्व मॉड्यूल तीन वर्गों को परिभाषित करता है -
अनु क्रमांक | शेल्व मॉड्यूल और विवरण |
---|---|
1 | Shelf यह शेल्फ कार्यान्वयन के लिए आधार वर्ग है। यह तानाशाही जैसी वस्तु से आरंभ किया जाता है। |
2 | BsdDbShelf यह शेल्फ क्लास का एक उपवर्ग है। इसके निर्माणकर्ता को दी गई प्रमुख वस्तु को पहले (), अगला (), पिछला (), अंतिम () और set_location () विधियों का समर्थन करना चाहिए। |
3 | DbfilenameShelf यह भी शेल्फ का एक उपवर्ग है, लेकिन इसके निर्माण के लिए एक पैरामीटर के रूप में एक फ़ाइलनाम को स्वीकार करता है, न कि प्रमुख वस्तु के बजाय। |
शेल्व मॉड्यूल में परिभाषित खुला () फ़ंक्शन जो वापस लौटाता है DbfilenameShelf वस्तु।
open(filename, flag='c', protocol=None, writeback=False)
फ़ाइलनाम पैरामीटर को बनाए गए डेटाबेस को सौंपा गया है। ध्वज पैरामीटर के लिए डिफ़ॉल्ट मान रीड / राइट एक्सेस के लिए 'c' है। अन्य झंडे 'डब्ल्यू' (केवल लिखें) 'आर' (केवल पढ़ने के लिए) और 'एन' (पढ़ने / लिखने के साथ नए) हैं।
धारावाहिकीकरण ही अचार प्रोटोकॉल द्वारा शासित होता है, डिफ़ॉल्ट रूप से कोई भी नहीं है। डिफ़ॉल्ट रूप से अंतिम पैरामीटर राइटबैक पैरामीटर गलत है। यदि सही पर सेट किया गया है, तो एक्सेस की गई प्रविष्टियों को कैश किया गया है। हर एक्सेस कॉल सिंक () और क्लोज़ () ऑपरेशंस, इसलिए प्रोसेस धीमा हो सकता है।
निम्नलिखित कोड एक डेटाबेस बनाता है और इसमें शब्दकोश प्रविष्टियां संग्रहीत करता है।
import shelve
s=shelve.open("test")
s['name']="Ajay"
s['age']=23
s['marks']=75
s.close()
यह वर्तमान निर्देशिका में test.dir फ़ाइल बनाएगा और हैश रूप में कुंजी-मूल्य डेटा संग्रहीत करेगा। शेल्फ ऑब्जेक्ट में निम्नलिखित तरीके उपलब्ध हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | close() सिंक्रनाइज़ करें और लगातार स्थिर वस्तु को बंद करें। |
2 | sync() कैश में सभी प्रविष्टियों को वापस लिखें यदि True पर राइटबैक सेट के साथ शेल्फ खोला गया था। |
3 | get() कुंजी के साथ जुड़ा हुआ मान लौटाता है |
4 | items() tuples की सूची - प्रत्येक tuple कुंजी मूल्य युग्म है |
5 | keys() शेल्फ कुंजी की सूची |
6 | pop() निर्दिष्ट कुंजी निकालें और संबंधित मान लौटाएं। |
7 | update() अन्य तानाशाह / पुनरावृत्ति से अद्यतन शेल्फ |
8 | values() शेल्फ मूल्यों की सूची |
शेल्फ में एक विशेष कुंजी के मूल्य तक पहुँचने के लिए -
s=shelve.open('test')
print (s['age']) #this will print 23
s['age']=25
print (s.get('age')) #this will print 25
s.pop('marks') #this will remove corresponding k-v pair
एक अंतर्निहित शब्दकोश वस्तु के रूप में, आइटम (), चाबियाँ () और मान () विधियां दृश्य वस्तुओं को वापस करती हैं।
print (list(s.items()))
[('name', 'Ajay'), ('age', 25), ('marks', 75)]
print (list(s.keys()))
['name', 'age', 'marks']
print (list(s.values()))
['Ajay', 25, 75]
शेल्फ़ उपयोग अद्यतन () विधि के साथ किसी अन्य शब्दकोश की वस्तुओं को मर्ज करने के लिए।
d={'salary':10000, 'designation':'manager'}
s.update(d)
print (list(s.items()))
[('name', 'Ajay'), ('age', 25), ('salary', 10000), ('designation', 'manager')]
डीबीएम पैकेज इंटरफ़ेस डीबीएम शैली डेटाबेस की तरह एक शब्दकोश प्रस्तुत करता है। DBM stands for DataBase Manager। इसका उपयोग UNIX (और UNIX like) ऑपरेटिंग सिस्टम द्वारा किया जाता है। Dbbm लाइब्रेरी केन थॉम्पसन द्वारा लिखा गया एक सरल डेटाबेस इंजन है। ये डेटाबेस बाइनरी एन्कोडेड स्ट्रिंग ऑब्जेक्ट्स को कुंजी के साथ-साथ मूल्य के रूप में उपयोग करते हैं।
डेटाबेस निश्चित आकार की बाल्टियों में एकल कुंजी (एक प्राथमिक कुंजी) का उपयोग करके डेटा संग्रहीत करता है और कुंजी द्वारा डेटा की तेजी से पुनर्प्राप्ति को सक्षम करने के लिए हैशिंग तकनीकों का उपयोग करता है।
Dbm पैकेज में निम्नलिखित मॉड्यूल शामिल हैं -
dbm.gnu मॉड्यूल डीबीएम पुस्तकालय संस्करण के लिए एक इंटरफ़ेस है जैसा कि जीएनयू परियोजना द्वारा कार्यान्वित किया जाता है।
dbm.ndbm मॉड्यूल UNIX nbdm कार्यान्वयन के लिए एक इंटरफ़ेस प्रदान करता है।
dbm.dumbईवेंट में फ़ॉलबैक विकल्प के रूप में उपयोग किया जाता है, अन्य डीबीएम कार्यान्वयन नहीं पाए जाते हैं। इसके लिए किसी बाहरी निर्भरता की आवश्यकता नहीं है, लेकिन दूसरों की तुलना में धीमी है।
>>> dbm.whichdb('mydbm.db')
'dbm.dumb'
>>> import dbm
>>> db=dbm.open('mydbm.db','n')
>>> db['name']=Raj Deshmane'
>>> db['address']='Kirtinagar Pune'
>>> db['PIN']='431101'
>>> db.close()
खुला () फ़ंक्शन इन झंडों को मोडने की अनुमति देता है -
अनु क्रमांक। | मूल्य और अर्थ |
---|---|
1 | 'r' केवल पढ़ने के लिए मौजूदा डेटाबेस खोलें (डिफ़ॉल्ट) |
2 | 'w' पढ़ने और लिखने के लिए मौजूदा डेटाबेस खोलें |
3 | 'c' पढ़ने और लिखने के लिए डेटाबेस खोलें, अगर यह मौजूद नहीं है तो इसे बनाएं |
4 | 'n' हमेशा एक नया, खाली डेटाबेस बनाएं, पढ़ने और लिखने के लिए खुला |
Dbm ऑब्जेक्ट ऑब्जेक्ट की तरह एक शब्दकोष है, जिस तरह शेल्फ ऑब्जेक्ट है। इसलिए, सभी शब्दकोश संचालन किया जा सकता है। Dbm ऑब्जेक्ट (), पॉप (), एपेंड () और अपडेट () विधियों को प्राप्त कर सकता है। निम्नलिखित कोड 'r' ध्वज के साथ 'mydbm.db' को खोलता है और कुंजी-मूल्य जोड़े के संग्रह पर प्रसारित होता है।
>>> db=dbm.open('mydbm.db','r')
>>> for k,v in db.items():
print (k,v)
b'name' : b'Raj Deshmane'
b'address' : b'Kirtinagar Pune'
b'PIN' : b'431101'
CSV stands for comma separated values। डेटाबेस में स्प्रेडशीट और डेटा टेबल से / को डेटा निर्यात / आयात करते समय यह फ़ाइल प्रारूप आमतौर पर उपयोग किया जाने वाला डेटा प्रारूप है। पीईवी 305 के परिणामस्वरूप सीएसवी मॉड्यूल को पायथन के मानक पुस्तकालय में शामिल किया गया था। यह पीईपी 305 की सिफारिशों के अनुसार सीएसवी फ़ाइल पर पढ़ने / लिखने के संचालन के लिए कक्षाएं और तरीके प्रस्तुत करता है।
CSV Microsoft के एक्सेल स्प्रेडशीट सॉफ़्टवेयर द्वारा एक पसंदीदा निर्यात डेटा प्रारूप है। हालाँकि, सीएसवी मॉड्यूल अन्य बोलियों द्वारा दर्शाए गए डेटा को भी संभाल सकता है।
CSV API इंटरफ़ेस में निम्नलिखित लेखक और पाठक वर्ग होते हैं -
लेखक ()
सीएसवी मॉड्यूल में यह फ़ंक्शन एक लेखक ऑब्जेक्ट देता है जो डेटा को सीमांकित स्ट्रिंग में परिवर्तित करता है और एक फ़ाइल ऑब्जेक्ट में संग्रहीत करता है। फ़ंक्शन को पैरामीटर के रूप में लिखित अनुमति के साथ फ़ाइल ऑब्जेक्ट की आवश्यकता होती है। फ़ाइल में लिखी गई प्रत्येक पंक्ति एक नया वर्ण जारी करती है। लाइनों के बीच अतिरिक्त स्थान को रोकने के लिए, newline पैरामीटर '' पर सेट है।
लेखक वर्ग के निम्नलिखित तरीके हैं -
writerow ()
यह विधि आइटम को एक पुनरावृत्त (सूची, टपल या स्ट्रिंग) में लिखती है, उन्हें अल्पविराम वर्ण द्वारा अलग करती है।
writerows ()
यह विधि पैरामीटर के रूप में पुनरावृत्तियों की एक सूची लेती है, और प्रत्येक आइटम को फ़ाइल में अल्पविराम से अलग लाइन के रूप में लिखती है।
Example
निम्नलिखित उदाहरण लेखक () फ़ंक्शन का उपयोग दिखाता है। सबसे पहले एक फाइल 'w ’मोड में खोली जाती है। इस फ़ाइल का उपयोग लेखक ऑब्जेक्ट प्राप्त करने के लिए किया जाता है। ट्यूपल्स की सूची में प्रत्येक ट्यूपल को तब राइटर () विधि का उपयोग करके फाइल करने के लिए लिखा जाता है।
import csv
persons=[('Lata',22,45),('Anil',21,56),('John',20,60)]
csvfile=open('persons.csv','w', newline='')
obj=csv.writer(csvfile)
for person in persons:
obj.writerow(person)
csvfile.close()
Output
यह करंट डायरेक्टरी में 'person.csv' फाइल बनाएगा। यह निम्नलिखित डेटा दिखाएगा।
Lata,22,45
Anil,21,56
John,20,60
प्रत्येक पंक्ति को व्यक्तिगत रूप से लिखने के लिए सूची पर पुनरावृत्ति करने के बजाय, हम लेखक () विधि का उपयोग कर सकते हैं।
csvfile=open('persons.csv','w', newline='')
persons=[('Lata',22,45),('Anil',21,56),('John',20,60)]
obj=csv.writer(csvfile)
obj.writerows(persons)
obj.close()
पाठक ()
यह फ़ंक्शन एक रीडर ऑब्जेक्ट लौटाता है जो लाइनों के एक पुनरावृत्त में देता है csv file। लूप के लिए नियमित रूप से उपयोग करते हुए, फ़ाइल में सभी लाइनें निम्न उदाहरण में प्रदर्शित की जाती हैं -
उदाहरण
csvfile=open('persons.csv','r', newline='')
obj=csv.reader(csvfile)
for row in obj:
print (row)
उत्पादन
['Lata', '22', '45']
['Anil', '21', '56']
['John', '20', '60']
पाठक वस्तु एक पुनरावृत्त है। इसलिए, यह अगले () फ़ंक्शन का समर्थन करता है जिसका उपयोग सीएसवी फ़ाइल के बजाय सभी लाइनों को प्रदर्शित करने के लिए किया जा सकता हैfor loop।
csvfile=open('persons.csv','r', newline='')
obj=csv.reader(csvfile)
while True:
try:
row=next(obj)
print (row)
except StopIteration:
break
जैसा कि पहले उल्लेख किया गया है, सीएसवी मॉड्यूल एक्सेल का उपयोग अपनी डिफ़ॉल्ट बोली के रूप में करता है। सीएसवी मॉड्यूल एक बोली वर्ग को भी परिभाषित करता है। बोली CSV प्रोटोकॉल को लागू करने के लिए उपयोग किए जाने वाले मानकों का सेट है। उपलब्ध बोलियों की सूची list_dialects () फ़ंक्शन द्वारा प्राप्त की जा सकती है।
>>> csv.list_dialects()
['excel', 'excel-tab', 'unix']
पुनरावृत्तियों के अलावा, सीएसवी मॉड्यूल सीएसवी फ़ाइल में एक शब्दकोश वस्तु निर्यात कर सकता है और इसे पायथन शब्दकोश वस्तु को आबाद करने के लिए पढ़ सकता है। इस प्रयोजन के लिए, यह मॉड्यूल निम्नलिखित वर्गों को परिभाषित करता है -
DictWriter ()
यह फ़ंक्शन DictWriter ऑब्जेक्ट देता है। यह लेखक वस्तु के समान है, लेकिन पंक्तियों को शब्दकोष में मैप किया जाता है। फ़ंक्शन को लिखित अनुमति और फ़ील्डनाम पैरामीटर के रूप में शब्दकोश में उपयोग की जाने वाली कुंजियों की सूची के साथ एक फ़ाइल ऑब्जेक्ट की आवश्यकता होती है। यह हेडर के रूप में फ़ाइल में पहली पंक्ति लिखने के लिए उपयोग किया जाता है।
writeheader ()
यह विधि फ़ाइल में पहली पंक्ति के रूप में अल्पविराम से पृथक रेखा के रूप में शब्दकोश में कुंजियों की सूची लिखती है।
निम्नलिखित उदाहरण में, शब्दकोश वस्तुओं की एक सूची परिभाषित की गई है। सूची में प्रत्येक आइटम एक शब्दकोश है। रिट्रो () विधि का उपयोग करते हुए, उन्हें कॉमा से अलग तरीके से फाइल करने के लिए लिखा जाता है।
persons=[
{'name':'Lata', 'age':22, 'marks':45},
{'name':'Anil', 'age':21, 'marks':56},
{'name':'John', 'age':20, 'marks':60}
]
csvfile=open('persons.csv','w', newline='')
fields=list(persons[0].keys())
obj=csv.DictWriter(csvfile, fieldnames=fields)
obj.writeheader()
obj.writerows(persons)
csvfile.close()
Person.csv फ़ाइल निम्न सामग्री दिखाती है -
name,age,marks
Lata,22,45
Anil,21,56
John,20,60
DictReader ()
यह फ़ंक्शन अंतर्निहित CSV फ़ाइल से DictReader ऑब्जेक्ट देता है। जैसा कि, रीडर ऑब्जेक्ट के मामले में, यह भी एक पुनरावृत्ति है, जिसके उपयोग से फ़ाइल की सामग्री पुनर्प्राप्त होती है।
csvfile=open('persons.csv','r', newline='')
obj=csv.DictReader(csvfile)
वर्ग फ़ील्ड नाम की विशेषता प्रदान करता है, फ़ाइल के हेडर के रूप में उपयोग की जाने वाली शब्दकोश कुंजियाँ लौटाता है।
print (obj.fieldnames)
['name', 'age', 'marks']
व्यक्तिगत डिक्शनरी ऑब्जेक्ट लाने के लिए DictReader ऑब्जेक्ट पर लूप का उपयोग करें।
for row in obj:
print (row)
यह निम्नलिखित उत्पादन में परिणाम -
OrderedDict([('name', 'Lata'), ('age', '22'), ('marks', '45')])
OrderedDict([('name', 'Anil'), ('age', '21'), ('marks', '56')])
OrderedDict([('name', 'John'), ('age', '20'), ('marks', '60')])
ऑर्डर डिडक्ट ऑब्जेक्ट को सामान्य डिक्शनरी में बदलने के लिए, हमें सबसे पहले ऑर्डरडीडक्ट को कलेक्शन मॉड्यूल से इंपोर्ट करना होगा।
from collections import OrderedDict
r=OrderedDict([('name', 'Lata'), ('age', '22'), ('marks', '45')])
dict(r)
{'name': 'Lata', 'age': '22', 'marks': '45'}
JSON खड़ा है JavaScript Object Notation। यह एक हल्का डाटा इंटरचेंज फॉर्मेट है। यह एक भाषा-स्वतंत्र और क्रॉस प्लेटफॉर्म टेक्स्ट प्रारूप है, जिसे कई प्रोग्रामिंग भाषाओं द्वारा समर्थित किया गया है। इस प्रारूप का उपयोग वेब सर्वर और क्लाइंट के बीच डेटा विनिमय के लिए किया जाता है।
JSON प्रारूप अचार के समान है। हालांकि, अचार क्रमबद्धता पायथन विशिष्ट है जबकि JSON प्रारूप कई भाषाओं द्वारा कार्यान्वित किया जाता है इसलिए यह सार्वभौमिक मानक बन गया है। पायथन की मानक लाइब्रेरी में json मॉड्यूल की कार्यक्षमता और इंटरफ़ेस अचार और मार्शल मॉड्यूल के समान है।
जिस तरह अचार मॉड्यूल में होता है, ठीक उसी तरह जसन मॉड्यूल भी प्रदान करता है dumps() तथा loads() JSON एन्कोडेड स्ट्रिंग में पायथन ऑब्जेक्ट के क्रमांकन के लिए फ़ंक्शन, और dump() तथा load() फ़ाइल में / से क्रमबद्ध पायथन ऑब्जेक्ट्स लिखते और पढ़ते हैं।
dumps() - यह फ़ंक्शन ऑब्जेक्ट को JSON फॉर्मेट में कनवर्ट करता है।
loads() - यह फ़ंक्शन पाइथन ऑब्जेक्ट में एक JSON स्ट्रिंग को परिवर्तित करता है।
निम्नलिखित उदाहरण इन कार्यों के मूल उपयोग को दर्शाता है -
import json
data=['Rakesh',{'marks':(50,60,70)}]
s=json.dumps(data)
json.loads(s)
डंप () फ़ंक्शन वैकल्पिक सॉर्ट_की तर्क ले सकता है। डिफ़ॉल्ट रूप से, यह गलत है। यदि True पर सेट किया गया है, तो JSON स्ट्रिंग में क्रमबद्ध क्रम में शब्दकोश कुंजियाँ दिखाई देती हैं।
डंप () फ़ंक्शन में इंडेंट नामक एक अन्य वैकल्पिक पैरामीटर होता है जो एक संख्या को मान के रूप में लेता है। यह प्रिंट आउटपुट के समान, जस स्ट्रिंग के स्वरूपित प्रतिनिधित्व के प्रत्येक खंड की लंबाई तय करता है।
Json मॉड्यूल में उपरोक्त कार्यों के अनुरूप ऑब्जेक्ट ओरिएंटेड API भी है। मॉड्यूल में दो वर्ग परिभाषित हैं - JSONEncoder और JSONDecoder।
JSONEncoder वर्ग
इस वर्ग का उद्देश्य पायथन डेटा संरचनाओं के लिए एनकोडर है। प्रत्येक पायथन डेटा प्रकार को संबंधित JSON प्रकार में परिवर्तित किया जाता है जैसा कि निम्नलिखित तालिका में दिखाया गया है -
अजगर | JSON |
---|---|
dict | वस्तु |
सूची, टपल | सरणी |
एसटीआर | तार |
int, फ्लोट, int- और फ्लोट-व्युत्पन्न Enums | संख्या |
सच | सच |
असत्य | असत्य |
कोई नहीं | शून्य |
JSONEncoder वर्ग JSONEncoder () निर्माता द्वारा तुरंत तैयार किया गया है। एनकोडर वर्ग में निम्नलिखित महत्वपूर्ण विधियों को परिभाषित किया गया है -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | encode() JSON प्रारूप में पायथन ऑब्जेक्ट को क्रमबद्ध करता है |
2 | iterencode() ऑब्जेक्ट को एनकोड करता है और ऑब्जेक्ट में प्रत्येक आइटम का एन्कोडेड उपज देने वाला एक इटर्मास्टर रिटर्न देता है। |
3 | indent एनकोडेड स्ट्रिंग का इंडेंट स्तर निर्धारित करता है |
4 | sort_keys कुंजी क्रमबद्ध क्रम में दिखाई दे या नहीं, यह सच है या गलत। |
5 | Check_circular यदि सही है, तो कंटेनर प्रकार ऑब्जेक्ट में परिपत्र संदर्भ देखें |
निम्नलिखित उदाहरण पायथन सूची ऑब्जेक्ट को एन्कोड करता है।
e=json.JSONEncoder()
e.encode(data)
JSONDecoder वर्ग
इस वर्ग की वस्तु पायथन डेटा संरचना के लिए जस स्ट्रिंग में वापस डिकोड करने में मदद करती है। इस वर्ग में मुख्य विधि डिकोड () है। उदाहरण के बाद कोड पहले चरण में एन्कोडेड स्ट्रिंग से पायथन सूची ऑब्जेक्ट को पुनः प्राप्त करता है।
d=json.JSONDecoder()
d.decode(s)
Json मॉड्यूल परिभाषित करता है load() तथा dump() JSON डेटा को ऑब्जेक्ट जैसी फ़ाइल में लिखने के लिए कार्य करता है - जो एक डिस्क फ़ाइल या बाइट स्ट्रीम हो सकती है और उनसे डेटा वापस पढ़ सकती है।
डंप ()
यह फ़ंक्शन किसी फ़ाइल में JSONed Python ऑब्जेक्ट डेटा लिखता है। फ़ाइल को 'w' मोड के साथ खोला जाना चाहिए।
import json
data=['Rakesh', {'marks': (50, 60, 70)}]
fp=open('json.txt','w')
json.dump(data,fp)
fp.close()
यह कोड वर्तमान निर्देशिका में 'json.txt' बनाएगा। यह सामग्री को निम्नानुसार दिखाता है -
["Rakesh", {"marks": [50, 60, 70]}]
भार()
यह फ़ंक्शन फ़ाइल से JSON डेटा लोड करता है और इसमें से पायथन ऑब्जेक्ट देता है। फ़ाइल को पठन अनुमति के साथ खोला जाना चाहिए (जिसमें 'r' मोड होना चाहिए)।
Example
fp=open('json.txt','r')
ret=json.load(fp)
print (ret)
fp.close()
Output
['Rakesh', {'marks': [50, 60, 70]}]
json.tool मॉड्यूल में एक कमांड-लाइन इंटरफ़ेस भी है जो फ़ाइल में डेटा को मान्य करता है और JSON ऑब्जेक्ट को एक बहुत प्रारूपित तरीके से प्रिंट करता है।
C:\python37>python -m json.tool json.txt
[
"Rakesh",
{
"marks": [
50,
60,
70
]
}
]
XML के लिए है eXtensible Markup Language। यह HTML, और SGML की तरह एक पोर्टेबल, ओपन सोर्स और क्रॉस प्लेटफॉर्म भाषा है और वर्ल्ड वाइड वेब कंसोर्टियम द्वारा अनुशंसित है।
यह एक प्रसिद्ध डेटा इंटरचेंज प्रारूप है, जिसका उपयोग बड़ी संख्या में अनुप्रयोगों जैसे कि वेब सेवा, कार्यालय उपकरण और द्वारा किया जाता है Service Oriented Architectures(SOA)। XML प्रारूप मशीन पठनीय और मानव पठनीय दोनों है।
मानक पायथन लाइब्रेरी के xml पैकेज में XML प्रोसेसिंग के लिए निम्नलिखित मॉड्यूल शामिल हैं -
अनु क्रमांक। | मॉड्यूल और विवरण |
---|---|
1 | xml.etree.ElementTree एलीमट्री एपीआई, एक सरल और हल्का XML प्रोसेसर |
2 | xml.dom DOM API परिभाषा |
3 | xml.dom.minidom एक न्यूनतम डोम कार्यान्वयन |
4 | xml.sax SAX2 इंटरफ़ेस कार्यान्वयन |
5 | xml.parsers.expat द एक्सपैट पारसर बाइंडिंग |
एक्सएमएल दस्तावेज़ में डेटा एक पेड़ की तरह पदानुक्रमित प्रारूप में व्यवस्थित होता है, जो रूट और तत्वों से शुरू होता है। प्रत्येक तत्व पेड़ में एक एकल नोड है और इसमें एक विशेषता है <> और </> टैग संलग्न हैं। एक या अधिक उप-तत्व प्रत्येक तत्व को सौंपा जा सकता है।
XML दस्तावेज़ का एक विशिष्ट उदाहरण निम्नलिखित है -
<?xml version = "1.0" encoding = "iso-8859-1"?>
<studentlist>
<student>
<name>Ratna</name>
<subject>Physics</subject>
<marks>85</marks>
</student>
<student>
<name>Kiran</name>
<subject>Maths</subject>
<marks>100</marks>
</student>
<student>
<name>Mohit</name>
<subject>Biology</subject>
<marks>92</marks>
</student>
</studentlist>
प्रयोग करते समय ElementTreeमॉड्यूल, पहला कदम पेड़ के मूल तत्व को स्थापित करना है। प्रत्येक तत्व में एक टैग और अट्रिब्यूट होता है जो एक तानाशाह वस्तु है। जड़ तत्व के लिए, एक अट्रिब्यूट एक खाली शब्दकोश है।
import xml.etree.ElementTree as xmlobj
root=xmlobj.Element('studentList')
अब, हम मूल तत्व के तहत एक या अधिक तत्व जोड़ सकते हैं। प्रत्येक तत्व वस्तु हो सकती हैSubElements। प्रत्येक सबलेमेंट में एक विशेषता और पाठ गुण होता है।
student=xmlobj.Element('student')
nm=xmlobj.SubElement(student, 'name')
nm.text='name'
subject=xmlobj.SubElement(student, 'subject')
nm.text='Ratna'
subject.text='Physics'
marks=xmlobj.SubElement(student, 'marks')
marks.text='85'
इस नए तत्व को एपेंड () विधि का उपयोग करके रूट से जोड़ा गया है।
root.append(student)
उपरोक्त विधि का उपयोग करके वांछित के रूप में कई तत्वों को जोड़ें। अंत में, रूट एलिमेंट ऑब्जेक्ट को किसी फ़ाइल में लिखा जाता है।
tree = xmlobj.ElementTree(root)
file = open('studentlist.xml','wb')
tree.write(file)
file.close()
अब, हम देखते हैं कि XML फ़ाइल को पार्स कैसे किया जाए। उसके लिए, ElementTree कंस्ट्रक्टर में फ़ाइल पैरामीटर के रूप में अपना नाम देने वाले दस्तावेज़ ट्री का निर्माण करें।
tree = xmlobj.ElementTree(file='studentlist.xml')
वृक्ष वस्तु है getroot() रूट एलीमेंट और गेटशिल्ड्रन प्राप्त करने की विधि () इसके नीचे के तत्वों की सूची देता है।
root = tree.getroot()
children = root.getchildren()
प्रत्येक उप तत्व से संबंधित एक डिक्शनरी ऑब्जेक्ट का निर्माण प्रत्येक बाल नोड के उप-तत्व संग्रह पर पुनरावृति द्वारा किया जाता है।
for child in children:
student={}
pairs = child.getchildren()
for pair in pairs:
product[pair.tag]=pair.text
प्रत्येक शब्दकोश को तब शब्दकोश वस्तुओं की मूल सूची लौटाने वाली सूची में जोड़ा जाता है।
SAXइवेंट-संचालित XML पार्सिंग के लिए एक मानक इंटरफ़ेस है। SAX के साथ XML को पार्स करने के लिए xml.sax.ContentHandler को उप-लिंक करके ContentHandler की आवश्यकता होती है। आप ब्याज की घटनाओं के लिए कॉलबैक रजिस्टर करते हैं और फिर, दस्तावेज़ के माध्यम से पार्सर को आगे बढ़ने देते हैं।
SAX तब उपयोगी होता है जब आपके दस्तावेज़ बड़े होते हैं या आपकी मेमोरी सीमाएँ होती हैं क्योंकि यह फ़ाइल को पार्स करता है क्योंकि यह डिस्क से इसे पढ़ता है परिणामस्वरूप पूरी फ़ाइल कभी भी मेमोरी में संग्रहीत नहीं होती है।
दस्तावेज़ ऑब्जेक्ट मॉडल
(DOM) API एक वर्ल्ड वाइड वेब कंसोर्टियम की सिफारिश है। इस स्थिति में, संपूर्ण फ़ाइल को मेमोरी में पढ़ा जाता है और एक XML दस्तावेज़ की सभी विशेषताओं का प्रतिनिधित्व करने के लिए एक पदानुक्रमित (ट्री-आधारित) रूप में संग्रहीत किया जाता है।
SAX, बड़ी फ़ाइलों के साथ DOM जितना तेज़ नहीं है। दूसरी ओर, कई छोटी फ़ाइलों पर उपयोग किए जाने पर, DOM संसाधनों को मार सकता है। SAX केवल-पढ़ने के लिए है, जबकि DOM XML फ़ाइल में परिवर्तन की अनुमति देता है।
Plist प्रारूप मुख्य रूप से MAC OS X द्वारा उपयोग किया जाता है। ये फाइलें मूल रूप से XML दस्तावेज हैं। वे किसी वस्तु के गुणों को संग्रहीत और पुनः प्राप्त करते हैं। पायथन लाइब्रेरी में प्लिस्ट मॉड्यूल होता है, जिसका उपयोग 'संपत्ति सूची' फ़ाइलों को पढ़ने और लिखने के लिए किया जाता है (वे आमतौर पर .plist 'एक्सटेंशन) होते हैं।
plistlib मॉड्यूल अधिक या कम अर्थ में अन्य क्रमांकन पुस्तकालयों के समान है, यह भी डंप () और भार () पायथन ऑब्जेक्ट्स के स्ट्रिंग प्रतिनिधित्व और लोड () और डंप () डिस्क संचालन के लिए फ़ंक्शन प्रदान करता है।
निम्नलिखित शब्दकोश वस्तु संपत्ति (कुंजी) और इसी मूल्य को बनाए रखता है -
proplist = {
"name" : "Ganesh",
"designation":"manager",
"dept":"accts",
"salary" : {"basic":12000, "da":4000, "hra":800}
}
डिस्क फ़ाइल में इन गुणों को लिखने के लिए, हम प्लिस्ट मॉड्यूल में डंप () फ़ंक्शन कहते हैं।
import plistlib
fileName=open('salary.plist','wb')
plistlib.dump(proplist, fileName)
fileName.close()
इसके विपरीत, संपत्ति के मूल्यों को वापस पढ़ने के लिए, लोड का उपयोग करें () फ़ंक्शन निम्नानुसार है -
fp= open('salary.plist', 'rb')
pl = plistlib.load(fp)
print(pl)
CSV, JSON, XML, आदि का एक बड़ा नुकसान यह है कि वे रैंडम एक्सेस और ट्रांजैक्शन प्रोसेसिंग के लिए बहुत उपयोगी नहीं हैं, क्योंकि वे काफी हद तक प्रकृति में असंरचित हैं। इसलिए, सामग्री को संशोधित करना बहुत मुश्किल हो जाता है।
ये फ्लैट फाइलें क्लाइंट-सर्वर वातावरण के लिए उपयुक्त नहीं हैं क्योंकि इनमें अतुल्यकालिक प्रसंस्करण क्षमता की कमी होती है। असंरचित डेटा फ़ाइलों का उपयोग करने से डेटा अतिरेक और असंगति होती है।
रिलेशनल डेटाबेस का उपयोग करके इन समस्याओं को दूर किया जा सकता है। डेटाबेस अतिरेक और असंगति को दूर करने और डेटा अखंडता को बनाए रखने के लिए डेटा का एक संगठित संग्रह है। संबंधपरक डेटाबेस मॉडल काफी लोकप्रिय है।
इसकी मूल अवधारणा इकाई तालिका (जिसे संबंध कहा जाता है) में डेटा की व्यवस्था करना है। इकाई तालिका संरचना एक विशेषता प्रदान करती है जिसका मूल्य प्रत्येक पंक्ति के लिए अद्वितीय है। ऐसी विशेषता को कहा जाता है'primary key'।
जब एक तालिका की प्राथमिक कुंजी अन्य तालिकाओं की संरचना में दिखाई देती है, तो इसे कहा जाता है 'Foreign key'और यह दोनों के बीच संबंध का आधार बनता है। इस मॉडल के आधार पर, वर्तमान में उपलब्ध कई लोकप्रिय RDBMS उत्पाद हैं -
- GadFly
- mSQL
- MySQL
- PostgreSQL
- Microsoft SQL Server 2000
- Informix
- Interbase
- Oracle
- Sybase
- SQLite
SQLite एक लाइटवेट रिलेशनल डेटाबेस है जिसका उपयोग विभिन्न प्रकार के अनुप्रयोगों में किया जाता है। यह एक स्व-निहित, सर्वर रहित, शून्य-कॉन्फ़िगरेशन, ट्रांसेक्शनल SQL डेटाबेस इंजन है। संपूर्ण डेटाबेस एक एकल फ़ाइल है, जिसे फ़ाइल सिस्टम में कहीं भी रखा जा सकता है। यह एक ओपन-सोर्स सॉफ़्टवेयर है, जिसमें बहुत छोटे पदचिह्न और शून्य कॉन्फ़िगरेशन हैं। यह लोकप्रिय रूप से एम्बेडेड उपकरणों, IOT और मोबाइल एप्लिकेशन में उपयोग किया जाता है।
सभी संबंधपरक डेटाबेस तालिकाओं में डेटा को संभालने के लिए SQL का उपयोग करते हैं। हालाँकि, पहले, इन डेटाबेसों में से प्रत्येक पायथन एप्लिकेशन के साथ जुड़ा हुआ था, जो कि डेटाबेस के प्रकार के लिए विशिष्ट पायथन मॉड्यूल की सहायता से किया गया था।
इसलिए, उनके बीच संगतता की कमी थी। यदि कोई उपयोगकर्ता अलग-अलग डेटाबेस उत्पाद में परिवर्तन करना चाहता है, तो यह मुश्किल साबित होगा। यह असंगति मुद्दा डीबी-एपीआई के रूप में जाना जाता है रिलेशनल डेटाबेस के लिए लगातार इंटरफेस की सिफारिश करने के लिए 'पायथन एन्हांसमेंट प्रपोजल (पीईपी 248)' को बढ़ाकर संबोधित किया गया था। नवीनतम सिफारिशों को कहा जाता हैDB-APIसंस्करण 2.0। (पीईपी 249)
पायथन के मानक पुस्तकालय में sqlite3 मॉड्यूल शामिल है जो Python प्रोग्राम के माध्यम से SQLite डेटाबेस को संभालने के लिए DB-API अनुरूप मॉड्यूल है। यह अध्याय Python की SQLite डेटाबेस के साथ कनेक्टिविटी की व्याख्या करता है।
जैसा कि पहले उल्लेख किया गया है, Python में sqlite3 मॉड्यूल के रूप में SQLite डेटाबेस के लिए इनबिल्ट समर्थन है। अन्य डेटाबेस के लिए, संबंधित डीबी-एपीआई आज्ञाकारी पायथन मॉड्यूल को पाइप उपयोगिता की मदद से स्थापित करना होगा। उदाहरण के लिए, MySQL डेटाबेस का उपयोग करने के लिए हमें PyMySQL मॉड्यूल को स्थापित करने की आवश्यकता है।
pip install pymysql
DB-API में निम्नलिखित चरणों की सिफारिश की गई है -
डेटाबेस का उपयोग करके कनेक्शन स्थापित करें connect() फ़ंक्शन और कनेक्शन ऑब्जेक्ट प्राप्त करें।
कॉल cursor() कर्सर ऑब्जेक्ट प्राप्त करने के लिए कनेक्शन ऑब्जेक्ट की विधि।
SQL कथन से बना क्वेरी स्ट्रिंग निष्पादित किया जाना चाहिए।
इच्छित क्वेरी को लागू करके निष्पादित करें execute() तरीका।
कनेक्शन बंद करें।
import sqlite3
db=sqlite3.connect('test.db')
यहाँ, db test.db का प्रतिनिधित्व करने वाली कनेक्शन वस्तु है। ध्यान दें, अगर वह पहले से मौजूद नहीं है तो वह डेटाबेस बनाया जाएगा। कनेक्शन ऑब्जेक्ट डीबी के निम्नलिखित तरीके हैं -
अनु क्रमांक। | तरीके और विवरण |
---|---|
1 | cursor(): एक कर्सर ऑब्जेक्ट लौटाता है जो इस कनेक्शन का उपयोग करता है। |
2 | commit(): स्पष्ट रूप से डेटाबेस के लिए कोई भी लंबित लेनदेन करता है। |
3 | rollback(): यह वैकल्पिक विधि लेनदेन को प्रारंभिक बिंदु पर वापस ले जाने का कारण बनती है। |
4 | close(): डेटाबेस से कनेक्शन को स्थायी रूप से बंद कर देता है। |
एक कर्सर एक दिए गए SQL क्वेरी के लिए हैंडल के रूप में कार्य करता है जो परिणाम के एक या अधिक पंक्तियों की पुनर्प्राप्ति की अनुमति देता है। निम्नलिखित कथन का उपयोग करते हुए SQL प्रश्नों को निष्पादित करने के लिए कनेक्शन से कर्सर ऑब्जेक्ट प्राप्त किया जाता है -
cur=db.cursor()
कर्सर ऑब्जेक्ट में निम्नलिखित तरीके परिभाषित हैं -
अनु क्रमांक | तरीके और विवरण |
---|---|
1 | execute() स्ट्रिंग पैरामीटर में SQL क्वेरी निष्पादित करता है। |
2 | executemany() Tuples की सूची में मापदंडों के एक सेट का उपयोग करके SQL क्वेरी को निष्पादित करता है। |
3 | fetchone() अगली पंक्ति को क्वेरी परिणाम सेट से प्राप्त करता है। |
4 | fetchall() क्वेरी परिणाम सेट से सभी शेष पंक्तियों को प्राप्त करता है। |
5 | callproc() एक संग्रहीत प्रक्रिया को कॉल करता है। |
6 | close() कर्सर ऑब्जेक्ट को बंद करता है। |
निम्नलिखित कोड test.db में एक तालिका बनाता है: -
import sqlite3
db=sqlite3.connect('test.db')
cur =db.cursor()
cur.execute('''CREATE TABLE student (
StudentID INTEGER PRIMARY KEY AUTOINCREMENT,
name TEXT (20) NOT NULL,
age INTEGER,
marks REAL);''')
print ('table created successfully')
db.close()
डेटाबेस में वांछित डेटा अखंडता हासिल की है commit() तथा rollback()कनेक्शन वस्तु के तरीके। SQL क्वेरी स्ट्रिंग एक गलत SQL क्वेरी हो सकती है जो अपवाद को बढ़ा सकती है, जिसे ठीक से हैंडल किया जाना चाहिए। उसके लिए, निष्पादित खंड () स्टेटम को ट्रायल ब्लॉक के भीतर रखा गया है। यदि यह सफल है, तो परिणाम लगातार कमिट () विधि का उपयोग करके सहेजा जाता है। यदि क्वेरी विफल हो जाती है, तो रोलबैक () पद्धति का उपयोग करके लेनदेन पूर्ववत है।
निम्नलिखित कोड छात्र तालिका में INSERT क्वेरी को test.db पर निष्पादित करता है।
import sqlite3
db=sqlite3.connect('test.db')
qry="insert into student (name, age, marks) values('Abbas', 20, 80);"
try:
cur=db.cursor()
cur.execute(qry)
db.commit()
print ("record added successfully")
except:
print ("error in query")
db.rollback()
db.close()
यदि आप उपयोगकर्ता इनपुट द्वारा गतिशील रूप से प्रदान किए गए INSERT क्वेरी के मान खंड में डेटा चाहते हैं, तो Python DB-API में अनुशंसित पैरामीटर प्रतिस्थापन का उपयोग करें। ? वर्ण का उपयोग क्वेरी स्ट्रिंग में प्लेसहोल्डर के रूप में किया जाता है और निष्पादन () विधि में एक टुपल के रूप में मान प्रदान करता है। निम्न उदाहरण पैरामीटर प्रतिस्थापन विधि का उपयोग करके एक रिकॉर्ड सम्मिलित करता है। नाम, आयु और अंकों को इनपुट के रूप में लिया जाता है।
import sqlite3
db=sqlite3.connect('test.db')
nm=input('enter name')
a=int(input('enter age'))
m=int(input('enter marks'))
qry="insert into student (name, age, marks) values(?,?,?);"
try:
cur=db.cursor()
cur.execute(qry, (nm,a,m))
db.commit()
print ("one record added successfully")
except:
print("error in operation")
db.rollback()
db.close()
Sqlite3 मॉड्यूल को परिभाषित करता है executemany()विधि जो एक साथ कई रिकॉर्ड जोड़ने में सक्षम है। जोड़े जाने वाले डेटा को ट्यूपल्स की सूची में दिया जाना चाहिए, प्रत्येक ट्यूपल में एक रिकॉर्ड होगा। सूची ऑब्जेक्ट क्वेरी स्ट्रिंग के साथ, निष्पादक () विधि का पैरामीटर है। हालाँकि, निष्पादक () विधि कुछ अन्य मॉड्यूल द्वारा समर्थित नहीं है।
UPDATEक्वेरी में आम तौर पर एक तार्किक अभिव्यक्ति होती है, जहां निर्दिष्ट किया गया है निष्पादन () विधि में क्वेरी स्ट्रिंग में एक UPDATE क्वेरी सिंटैक्स होना चाहिए। नाम = 'अनिल' के लिए 'आयु' के मान को 23 पर अपडेट करने के लिए, नीचे दिए गए स्ट्रिंग को परिभाषित करें:
qry="update student set age=23 where name='Anil';"
अद्यतन प्रक्रिया को अधिक गतिशील बनाने के लिए, हम ऊपर वर्णित अनुसार पैरामीटर प्रतिस्थापन विधि का उपयोग करते हैं।
import sqlite3
db=sqlite3.connect('test.db')
nm=input(‘enter name’)
a=int(input(‘enter age’))
qry="update student set age=? where name=?;"
try:
cur=db.cursor()
cur.execute(qry, (a, nm))
db.commit()
print("record updated successfully")
except:
print("error in query")
db.rollback()
db.close()
इसी तरह, DELETE ऑपरेशन SQL के DELETE क्वेरी सिंटैक्स वाले स्ट्रिंग के साथ निष्पादित () विधि को कॉल करके किया जाता है। संयोग से,DELETE क्वेरी में भी आम तौर पर एक होता है WHERE खंड।
import sqlite3
db=sqlite3.connect('test.db')
nm=input(‘enter name’)
qry="DELETE from student where name=?;"
try:
cur=db.cursor()
cur.execute(qry, (nm,))
db.commit()
print("record deleted successfully")
except:
print("error in operation")
db.rollback()
db.close()
एक डेटाबेस टेबल पर एक महत्वपूर्ण संचालन से रिकॉर्ड की पुनर्प्राप्ति है। एसक्यूएल प्रदान करता हैSELECTउद्देश्य के लिए क्वेरी। जब SEL क्वेरी क्वेरी सिंटैक्स वाली स्ट्रिंग को निष्पादित () विधि के लिए दिया जाता है, तो परिणाम सेट ऑब्जेक्ट वापस आ जाता है। एक कर्सर ऑब्जेक्ट के साथ दो महत्वपूर्ण विधियां हैं, जिसके उपयोग से परिणाम सेट से एक या कई रिकॉर्ड प्राप्त किए जा सकते हैं।
fetchone ()
परिणाम सेट से अगला उपलब्ध रिकॉर्ड प्राप्त करता है। यह एक रिकॉर्ड है जिसमें भ्रूण के रिकॉर्ड के प्रत्येक कॉलम के मान शामिल हैं।
fetchall ()
बचे हुए सभी रिकॉर्डों को टुपल्स की सूची के रूप में प्राप्त करता है। प्रत्येक टपल एक रिकॉर्ड से मेल खाती है और तालिका में प्रत्येक कॉलम के मान सम्मिलित हैं।
निम्नलिखित उदाहरण छात्र तालिका में सभी रिकॉर्डों को सूचीबद्ध करता है
import sqlite3
db=sqlite3.connect('test.db')
37
sql="SELECT * from student;"
cur=db.cursor()
cur.execute(sql)
while True:
record=cur.fetchone()
if record==None:
break
print (record)
db.close()
यदि आप SQLite डेटाबेस के बजाय एक MySQL डेटाबेस का उपयोग करने की योजना बनाते हैं, तो आपको इंस्टॉल करने की आवश्यकता है PyMySQLमॉड्यूल जैसा कि ऊपर वर्णित है। डेटाबेस कनेक्टिविटी प्रक्रिया में सभी चरण समान हैं, क्योंकि MySQL डेटाबेस एक सर्वर पर स्थापित है, कनेक्ट () फ़ंक्शन को URL और लॉगिन क्रेडेंशियल्स की आवश्यकता है।
import pymysql
con=pymysql.connect('localhost', 'root', '***')
केवल एक चीज जो SQLite के साथ भिन्न हो सकती है वह है MySQL विशिष्ट डेटा प्रकार। इसी तरह, किसी भी ODBC संगत डेटाबेस का उपयोग पायोडबक मॉड्यूल स्थापित करके पायथन के साथ किया जा सकता है।
कोई भी संबंधपरक डेटाबेस तालिकाओं में डेटा रखता है। तालिका संरचना डेटा प्रकार की विशेषताओं को परिभाषित करती है जो मूल रूप से प्राथमिक डेटा प्रकारों की होती हैं जो केवल संबंधित डेटा प्रकारों पायथन में मैप की जाती हैं। हालाँकि, पायथन के उपयोगकर्ता-परिभाषित ऑब्जेक्ट्स को SQL टेबल से लगातार संग्रहीत और पुनः प्राप्त नहीं किया जा सकता है।
यह SQL प्रकार और ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग भाषाओं जैसे पायथन के बीच असमानता है। SQL में दूसरों के लिए समान डेटा प्रकार नहीं है जैसे तानाशाह, टपल, सूची या कोई भी उपयोगकर्ता परिभाषित वर्ग।
यदि आपको किसी रिलेशनल डेटाबेस में ऑब्जेक्ट को स्टोर करना है, तो इंस्टेंस क्वेरी को निष्पादित करने से पहले, यह उदाहरण विशेषताएँ SQL डेटा प्रकारों में डिकॉन्स्ट्रक्ट किया जाना चाहिए। दूसरी ओर, SQL तालिका से प्राप्त डेटा प्राथमिक प्रकारों में है। पाइथन लिपि में उपयोग के लिए इच्छित प्रकार की एक पाइथन वस्तु का निर्माण करना होगा। यह वह जगह है जहाँ ऑब्जेक्ट रिलेशनल मैपर उपयोगी होते हैं।
ऑब्जेक्ट रिलेशन मैपर (ORM)
एक Object Relation Mapper(ORM) एक वर्ग और एक SQL तालिका के बीच का इंटरफ़ेस है। एक पायथन वर्ग को डेटाबेस में एक निश्चित तालिका में मैप किया जाता है, ताकि ऑब्जेक्ट और SQL प्रकारों के बीच रूपांतरण स्वचालित रूप से किया जाए।
पायथन कोड में लिखा गया छात्र वर्ग डेटाबेस में छात्र तालिका में मैप किया जाता है। नतीजतन, सभी सीआरयूडी संचालन कक्षा के संबंधित तरीकों को कॉल करके किया जाता है। यह अजगर स्क्रिप्ट में हार्ड कोडित एसक्यूएल प्रश्नों को निष्पादित करने की आवश्यकता को समाप्त करता है।
ORM पुस्तकालय इस प्रकार कच्चे SQL प्रश्नों पर एक अमूर्त परत के रूप में कार्य करता है और तेजी से अनुप्रयोग विकास में मदद कर सकता है। SQLAlchemyपायथन के लिए एक लोकप्रिय वस्तु संबंधपरक मैपर है। मॉडल ऑब्जेक्ट की स्थिति के किसी भी हेरफेर को डेटाबेस तालिका में इसकी संबंधित पंक्ति के साथ सिंक्रनाइज़ किया जाता है।
SQLALchemy लाइब्रेरी शामिल है ORM API और SQL अभिव्यक्ति भाषा (SQLAlchemy Core)। अभिव्यक्ति भाषा सीधे रिलेशनल डेटाबेस के आदिम निर्माण को निष्पादित करती है।
ORM SQL अभिव्यक्ति भाषा के शीर्ष पर निर्मित उपयोग का एक उच्च स्तरीय और अमूर्त पैटर्न है। यह कहा जा सकता है कि ORM अभिव्यक्ति भाषा का एक अनुप्रयुक्त उपयोग है। हम SQLAlchemy ORM API पर चर्चा करेंगे और इस विषय में SQLite डेटाबेस का उपयोग करेंगे।
SQLAlchemy अपने संबंधित DBAPI कार्यान्वयन के माध्यम से विभिन्न प्रकार के डेटाबेस के साथ एक बोली प्रणाली का उपयोग करके संचार करता है। सभी बोलियों के लिए आवश्यक है कि एक उपयुक्त DBAPI ड्राइवर स्थापित हो। निम्नलिखित प्रकार के डेटाबेस के लिए बोलियाँ शामिल हैं -
- Firebird
- Microsoft SQL सर्वर
- MySQL
- Oracle
- PostgreSQL
- SQLite
- Sybase
पाइप उपयोगिता का उपयोग करते हुए SQLAlchemy की स्थापना आसान और सरल है।
pip install sqlalchemy
यह जांचने के लिए कि क्या SQLalchemy ठीक से स्थापित है और इसका संस्करण, पायथन प्रॉम्प्ट पर निम्नलिखित दर्ज करें -
>>> import sqlalchemy
>>>sqlalchemy.__version__
'1.3.11'
डेटाबेस के साथ बातचीत इंजन ऑब्जेक्ट के माध्यम से की जाती है जो रिटर्न वैल्यू के रूप में प्राप्त होती है create_engine() समारोह।
engine =create_engine('sqlite:///mydb.sqlite')
SQLite इन-मेमोरी डेटाबेस के निर्माण की अनुमति देता है। इन-मेमोरी डेटाबेस के लिए SQLAlchemy इंजन निम्नानुसार बनाया गया है -
from sqlalchemy import create_engine
engine=create_engine('sqlite:///:memory:')
यदि आप इसके बजाय MySQL डेटाबेस का उपयोग करने का इरादा रखते हैं, तो इसके DB-API मॉड्यूल - pymysql और संबंधित बोली ड्राइवर का उपयोग करें।
engine = create_engine('mysql+pymydsql://root@localhost/mydb')
Create_engine में एक वैकल्पिक प्रतिध्वनि तर्क है। यदि यह सही है, तो इंजन द्वारा उत्पन्न SQL क्वेरी टर्मिनल पर गूँजती होगी।
SQLAlchemy शामिल हैं declarative baseकक्षा। यह मॉडल वर्गों और मैप किए गए तालिकाओं की एक सूची के रूप में कार्य करता है।
from sqlalchemy.ext.declarative import declarative_base
base=declarative_base()
अगला कदम एक मॉडल वर्ग को परिभाषित करना है। इसे आधार से घोषित किया जाना चाहिए - ऊपर के रूप में घोषणात्मक_बेस वर्ग की वस्तु।
सेट __tablename__ आपके द्वारा डेटाबेस में बनाई गई तालिका के नाम की संपत्ति। अन्य विशेषताएँ खेतों के अनुरूप हैं। SQLAlchemy में हर एक एक कॉलम ऑब्जेक्ट है और इसका डेटा प्रकार नीचे दी गई सूची में से एक है -
- BigInteger
- Boolean
- Date
- DateTime
- Float
- Integer
- Numeric
- SmallInteger
- String
- Text
- Time
निम्नलिखित कोड छात्र वर्ग का नाम है जिसे छात्र तालिका में मैप किया जाता है।
#myclasses.py
from sqlalchemy.ext.declarative import declarative_base
from sqlalchemy import Column, Integer, String, Numeric
base=declarative_base()
class Student(base):
__tablename__='Students'
StudentID=Column(Integer, primary_key=True)
name=Column(String)
age=Column(Integer)
marks=Column(Numeric)
एक छात्र तालिका बनाने के लिए, जिसके पास एक समान संरचना है, आधार वर्ग के लिए create_all () पद्धति को निष्पादित करें।
base.metadata.create_all(engine)
अब हमें अपने छात्र वर्ग की एक वस्तु घोषित करनी होगी। सभी डेटाबेस लेनदेन जैसे डेटाबेस से डेटा जोड़ना, हटाना या पुनर्प्राप्त करना, एक सेशन ऑब्जेक्ट द्वारा नियंत्रित किया जाता है।
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
sessionobj = Session()
छात्र के ऑब्जेक्ट में संग्रहीत डेटा को सत्र के ऐड () विधि द्वारा भौतिक रूप से अंतर्निहित तालिका में जोड़ा जाता है।
s1 = Student(name='Juhi', age=25, marks=200)
sessionobj.add(s1)
sessionobj.commit()
यहां, छात्रों की तालिका में रिकॉर्ड जोड़ने के लिए संपूर्ण कोड है। जैसे ही इसे निष्पादित किया जाता है, संगत SQL स्टेटमेंट लॉग कंसोल पर प्रदर्शित होता है।
from sqlalchemy import Column, Integer, String
from sqlalchemy import create_engine
from myclasses import Student, base
engine = create_engine('sqlite:///college.db', echo=True)
base.metadata.create_all(engine)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
sessionobj = Session()
s1 = Student(name='Juhi', age=25, marks=200)
sessionobj.add(s1)
sessionobj.commit()
कंसोल आउटपुट
CREATE TABLE "Students" (
"StudentID" INTEGER NOT NULL,
name VARCHAR,
age INTEGER,
marks NUMERIC,
PRIMARY KEY ("StudentID")
)
INFO sqlalchemy.engine.base.Engine ()
INFO sqlalchemy.engine.base.Engine COMMIT
INFO sqlalchemy.engine.base.Engine BEGIN (implicit)
INFO sqlalchemy.engine.base.Engine INSERT INTO "Students" (name, age, marks) VALUES (?, ?, ?)
INFO sqlalchemy.engine.base.Engine ('Juhi', 25, 200.0)
INFO sqlalchemy.engine.base.Engine COMMIT
session ऑब्जेक्ट एकल लेनदेन में एक से अधिक ऑब्जेक्ट सम्मिलित करने के लिए add_all () विधि भी प्रदान करता है।
sessionobj.add_all([s2,s3,s4,s5])
sessionobj.commit()
अब, रिकॉर्ड्स को तालिका में जोड़ा जाता है, हम इसे उसी तरह से प्राप्त करना चाहेंगे, जैसा कि SELECT क्वेरी करती है। सत्र ऑब्जेक्ट में कार्य करने के लिए क्वेरी () विधि है। क्वेरी ऑब्जेक्ट हमारे छात्र मॉडल पर क्वेरी () विधि द्वारा लौटाया जाता है।
qry=seesionobj.query(Student)
इस क्वेरी ऑब्जेक्ट के प्राप्त () विधि का उपयोग करें दी गई प्राथमिक कुंजी के अनुरूप वस्तु।
S1=qry.get(1)
जबकि इस कथन को निष्पादित किया जाता है, कंसोल पर प्रतिध्वनित होने वाली इसकी एसक्यूएल स्टेटमेंट निम्नानुसार होगी -
BEGIN (implicit)
SELECT "Students"."StudentID" AS "Students_StudentID", "Students".name AS
"Students_name", "Students".age AS "Students_age",
"Students".marks AS "Students_marks"
FROM "Students"
WHERE "Products"."Students" = ?
sqlalchemy.engine.base.Engine (1,)
Query.all () विधि उन सभी ऑब्जेक्ट्स की एक सूची देता है, जिन्हें लूप का उपयोग करके ट्रेस किया जा सकता है।
from sqlalchemy import Column, Integer, String, Numeric
from sqlalchemy import create_engine
from myclasses import Student,base
engine = create_engine('sqlite:///college.db', echo=True)
base.metadata.create_all(engine)
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(bind=engine)
sessionobj = Session()
qry=sessionobj.query(Students)
rows=qry.all()
for row in rows:
print (row)
मैप की गई तालिका में रिकॉर्ड अपडेट करना बहुत आसान है। आपको केवल प्राप्त () विधि का उपयोग करके एक रिकॉर्ड प्राप्त करना है, वांछित विशेषता के लिए एक नया मान असाइन करें और फिर सत्र ऑब्जेक्ट का उपयोग करके परिवर्तन करें। नीचे हम जूही छात्र के अंकों को 100 में बदलते हैं।
S1=qry.get(1)
S1.marks=100
sessionobj.commit()
सत्र से वांछित वस्तु को हटाकर एक रिकॉर्ड को हटाना उतना ही आसान है।
S1=qry.get(1)
Sessionobj.delete(S1)
sessionobj.commit()
MongoDB एक दस्तावेज़ उन्मुख है NoSQLडेटाबेस। यह एक क्रॉस प्लेटफॉर्म डेटाबेस है जो सर्वर साइड पब्लिक लाइसेंस के तहत वितरित किया जाता है। यह JSON जैसे डॉक्यूमेंट्स को स्कीमा के रूप में उपयोग करता है।
विशाल डेटा को संग्रहीत करने की क्षमता प्रदान करने के लिए, एक से अधिक भौतिक सर्वर (जिन्हें शार्क कहा जाता है) आपस में जुड़े हुए हैं, ताकि एक क्षैतिज मापनीयता प्राप्त हो। MongoDB डेटाबेस में दस्तावेज़ होते हैं।
एक दस्तावेज संबंधपरक डेटाबेस की तालिका में एक पंक्ति के अनुरूप है। हालाँकि, इसमें कोई विशेष स्कीमा नहीं है। दस्तावेज़ कुंजी-मूल्य जोड़े का एक संग्रह है - शब्दकोश के समान। हालाँकि, प्रत्येक दस्तावेज़ में kv जोड़े की संख्या भिन्न हो सकती है। जिस तरह से रिलेशनल डेटाबेस में एक टेबल के पास एक प्राथमिक कुंजी होती है, उसी तरह से दस्तावेज़ में MongoDB डेटाबेस की एक विशेष कुंजी होती है"_id"।
पहले हम देखते हैं कि पायथन के साथ MongoDB डेटाबेस का उपयोग कैसे किया जाता है, आइए हम संक्षेप में समझते हैं कि MongoDB कैसे स्थापित करें और शुरू करें। MongoDB का सामुदायिक और व्यावसायिक संस्करण उपलब्ध है। समुदाय संस्करण को www.mongodb.com/download-center/community से डाउनलोड किया जा सकता है ।
मान लिया जाता है कि MongoDB c: \ mongodb में स्थापित है, सर्वर को निम्न आदेश का उपयोग करके लागू किया जा सकता है।
c:\mongodb\bin>mongod
MongoDB सर्वर डिफ़ॉल्ट रूप से पोर्ट नंबर 22017 पर सक्रिय है। डेटाबेस डेटा / बिन फ़ोल्डर में डिफ़ॉल्ट रूप से संग्रहीत होते हैं, हालांकि स्थान को -dbpath विकल्प द्वारा बदला जा सकता है।
MongoDB के पास MongoDB शेल में उपयोग किए जाने वाले कमांड का अपना सेट है। शेल आह्वान करने के लिए, का उपयोग करेंMongo आदेश।
x:\mongodb\bin>mongo
MySQL या SQLite शेल प्रॉम्प्ट के समान एक शेल प्रॉम्प्ट, जिसके सामने देशी NoSQL कमांड निष्पादित किया जा सकता है। हालाँकि, हम MongoDB डेटाबेस को पायथन से जोड़ने में रुचि रखते हैं।
PyMongoपायथन प्रोग्रामिंग इंटरफ़ेस प्रदान करने के लिए स्वयं MongoDB इंक द्वारा मॉड्यूल विकसित किया गया है। PyMongo को स्थापित करने के लिए अच्छी तरह से ज्ञात पाइप उपयोगिता का उपयोग करें।
pip3 install pymongo
मान लिया कि MongoDB सर्वर ऊपर और चल रहा है (के साथ) mongod कमांड) और 22017 पोर्ट पर सुन रहा है, हमें पहले एक घोषणा करने की आवश्यकता है MongoClientवस्तु। यह पायथन सत्र और डेटाबेस के बीच सभी लेनदेन को नियंत्रित करता है।
from pymongo import MongoClient
client=MongoClient()
MongoDB सर्वर के साथ संबंध स्थापित करने के लिए इस क्लाइंट ऑब्जेक्ट का उपयोग करें।
client = MongoClient('localhost', 27017)
एक नया डेटाबेस निम्नलिखित कमांड के साथ बनाया गया है।
db=client.newdb
एक संबंधपरक डेटाबेस में टेबल के समान, MongoDB डेटाबेस में कई संग्रह हो सकते हैं। एक संग्रह वस्तु द्वारा बनाई गई हैCreate_collection() समारोह।
db.create_collection('students')
अब, हम संग्रह में एक या एक से अधिक दस्तावेज जोड़ सकते हैं -
from pymongo import MongoClient
client=MongoClient()
db=client.newdb
db.create_collection("students")
student=db['students']
studentlist=[{'studentID':1,'Name':'Juhi','age':20, 'marks'=100},
{'studentID':2,'Name':'dilip','age':20, 'marks'=110},
{'studentID':3,'Name':'jeevan','age':24, 'marks'=145}]
student.insert_many(studentlist)
client.close()
दस्तावेजों को पुनः प्राप्त करने के लिए (चयन क्वेरी के समान), हमें उपयोग करना चाहिए find()तरीका। यह एक कर्सर लौटाता है जिसकी मदद से सभी दस्तावेज़ प्राप्त किए जा सकते हैं।
students=db['students']
docs=students.find()
for doc in docs:
print (doc['Name'], doc['age'], doc['marks'] )
एक संग्रह में उन सभी के बजाय एक विशेष दस्तावेज़ खोजने के लिए, हमें () विधि खोजने के लिए फ़िल्टर लागू करने की आवश्यकता है। फ़िल्टर तार्किक ऑपरेटरों का उपयोग करता है। MongoDB नीचे के रूप में तार्किक ऑपरेटरों का अपना सेट है -
अनु क्रमांक | MongoDB ऑपरेटर और पारंपरिक तार्किक ऑपरेटर |
---|---|
1 | $eq के बराबर (==) |
2 | $gt से अधिक (>) |
3 | $gte से अधिक या इसके बराबर (> =) |
4 | $in यदि सरणी में किसी भी मान के बराबर है |
5 | $lt से कम (<) |
6 | $lte से कम या इसके बराबर (<=) |
7 | $ne (=) के बराबर नहीं |
8 | $nin यदि सरणी में किसी भी मान के बराबर नहीं है |
उदाहरण के लिए, हम 21 वर्ष से अधिक उम्र के छात्रों की सूची प्राप्त करने में रुचि रखते हैं। के लिए फ़िल्टर में $ gt ऑपरेटर का उपयोग करनाfind() विधि इस प्रकार है -
students=db['students']
docs=students.find({'age':{'$gt':21}})
for doc in docs:
print (doc.get('Name'), doc.get('age'), doc.get('marks'))
PyMongo मॉड्यूल प्रदान करता है update_one() तथा update_many() एक विशिष्ट फ़िल्टर अभिव्यक्ति को संतुष्ट करते हुए एक दस्तावेज़ या एक से अधिक दस्तावेज़ों को संशोधित करने के तरीके।
आइए हम एक दस्तावेज की विशेषता को चिह्नित करते हैं जिसमें नाम जूही है।
from pymongo import MongoClient
client=MongoClient()
db=client.newdb
doc=db.students.find_one({'Name': 'Juhi'})
db['students'].update_one({'Name': 'Juhi'},{"$set":{'marks':150}})
client.close()
कैसंड्रा एक और लोकप्रिय NoSQL डेटाबेस है। उच्च मापनीयता, संगति और दोष-सहिष्णुता - ये कैसंड्रा की कुछ महत्वपूर्ण विशेषताएं हैं। ये हैColumn storeडेटाबेस। डेटा को कई कमोडिटी सर्वरों में संग्रहीत किया जाता है। परिणामस्वरूप, अत्यधिक उपलब्ध डेटा।
कैसांद्रा अपाचे सॉफ्टवेयर फाउंडेशन का एक उत्पाद है। डेटा को कई नोड्स में वितरित तरीके से संग्रहीत किया जाता है। प्रत्येक नोड एक एकल सर्वर होता है जिसमें कीस्पेस होते हैं। कैसंड्रा डेटाबेस का मौलिक निर्माण खंड हैkeyspace जिसे एक डेटाबेस के अनुरूप माना जा सकता है।
कैसंड्रा के एक नोड में डेटा, नोड्स के पीयर-टू-पीयर नेटवर्क पर अन्य नोड्स में दोहराया जाता है। यह कैसेंड्रा को एक मूर्खतापूर्ण डेटाबेस बनाता है। नेटवर्क को डाटा सेंटर कहा जाता है। एक क्लस्टर बनाने के लिए कई डेटा केंद्र आपस में जुड़े हो सकते हैं। प्रतिकृति की प्रकृति एक कीस्पेस के निर्माण के समय प्रतिकृति रणनीति और प्रतिकृति कारक सेट करके कॉन्फ़िगर की गई है।
एक कीस्पेस में एक से अधिक कॉलम परिवार हो सकते हैं - जैसे एक डेटाबेस में कई टेबल हो सकते हैं। कैसेंड्रा के कीस्पेस में कोई पूर्वनिर्धारित स्कीमा नहीं है। यह संभव है कि कैसंड्रा तालिका में प्रत्येक पंक्ति में अलग-अलग नामों के साथ और चर संख्या में कॉलम हो सकते हैं।
कैसंड्रा सॉफ्टवेयर दो संस्करणों में भी उपलब्ध है: समुदाय और उद्यम। कैसांद्रा का नवीनतम उद्यम संस्करण डाउनलोड के लिए उपलब्ध हैhttps://cassandra.apache.org/download/। सामुदायिक संस्करण में पाया जाता हैhttps://academy.datastax.com/planet-cassandra/cassandra।
कैसंड्रा की अपनी क्वेरी भाषा होती है Cassandra Query Language (CQL)। CQL प्रश्नों को CQLASH शेल के अंदर से निष्पादित किया जा सकता है - MySQL या SQLite शेल के समान। CQL सिंटैक्स मानक SQL के समान दिखाई देता है।
डेटास्टैक्स समुदाय संस्करण, निम्नलिखित आंकड़ों में दिखाए गए एक Develcenter IDE के साथ भी आता है -
कैसंड्रा डेटाबेस के साथ काम करने के लिए पायथन मॉड्यूल को कहा जाता है Cassandra Driver। यह अपाचे नींव द्वारा भी विकसित किया गया है। इस मॉड्यूल में ORM API, साथ ही संबंधपरक डेटाबेस के लिए DB-API के समान प्रकृति का एक कोर एपीआई है।
कैसेंड्रा चालक की स्थापना आसानी से उपयोग करके की जाती है pip utility।
pip3 install cassandra-driver
कैसंड्रा डेटाबेस के साथ सहभागिता, क्लस्टर ऑब्जेक्ट के माध्यम से किया जाता है। Cassandra.cluster मॉड्यूल क्लस्टर श्रेणी को परिभाषित करता है। हमें पहले क्लस्टर ऑब्जेक्ट घोषित करने की आवश्यकता है।
from cassandra.cluster import Cluster
clstr=Cluster()
सभी लेनदेन जैसे इन्सर्ट / अपडेट इत्यादि, एक कीस्पेस के साथ एक सत्र शुरू करके किया जाता है।
session=clstr.connect()
एक नया कीस्पेस बनाने के लिए, का उपयोग करें execute()सत्र वस्तु की विधि। निष्पादित () विधि एक स्ट्रिंग तर्क लेती है जो एक क्वेरी स्ट्रिंग होना चाहिए। CQL में निम्न प्रकार से रचनात्मक कथन है। पूरा कोड नीचे दिया गया है -
from cassandra.cluster import Cluster
clstr=Cluster()
session=clstr.connect()
session.execute(“create keyspace mykeyspace with replication={
'class': 'SimpleStrategy', 'replication_factor' : 3
};”
यहाँ, SimpleStrategy के लिए एक मूल्य है replication strategy तथा replication factor3 पर सेट किया गया है। जैसा कि पहले उल्लेख किया गया है, एक केस्पेस में एक या अधिक टेबल होते हैं। प्रत्येक तालिका को डेटा प्रकार की विशेषता है। पायथन डेटा प्रकार निम्नलिखित तालिका के अनुसार संबंधित CQL डेटा प्रकारों के साथ स्वचालित रूप से पार्स किए जाते हैं -
अजगर का प्रकार | CQL प्रकार |
---|---|
कोई नहीं | शून्य |
बूल | बूलियन |
फ्लोट | फ्लोट, डबल |
int, लंबा | int, bigint, varint, smallint, smallint, counter |
decimal.Decimal | दशमलव |
str, यूनिकोड | ascii, varchar, पाठ |
बफ़र, बायट्रेयर | ब्लॉब |
दिनांक | दिनांक |
दिनांक और समय | समय-चिह्न |
समय | समय |
सूची, टपल, जनरेटर | सूची |
सेट, फ्रोज़ेनसेट | सेट |
तानाशाही, आदेश | नक्शा |
uuid.UUID | timeuuid, uuid |
तालिका बनाने के लिए, तालिका बनाने के लिए CQL क्वेरी को निष्पादित करने के लिए सत्र ऑब्जेक्ट का उपयोग करें।
from cassandra.cluster import Cluster
clstr=Cluster()
session=clstr.connect('mykeyspace')
qry= '''
create table students (
studentID int,
name text,
age int,
marks int,
primary key(studentID)
);'''
session.execute(qry)
बनाए गए कीस्पेस को आगे पंक्तियों को डालने के लिए उपयोग किया जा सकता है। INSERT क्वेरी का CQL संस्करण SQL सम्मिलित कथन के समान है। निम्नलिखित कोड छात्रों की तालिका में एक पंक्ति सम्मिलित करता है।
from cassandra.cluster import Cluster
clstr=Cluster()
session=clstr.connect('mykeyspace')
session.execute("insert into students (studentID, name, age, marks) values
(1, 'Juhi',20, 200);"
जैसा कि आप उम्मीद करेंगे, कैसेंड्रा के साथ SELECT स्टेटमेंट का भी उपयोग किया जाता है। निष्पादित क्वेरी विधि () में, सेलेक्ट क्वेरी क्वेरी वाली विधि है, यह एक परिणाम सेट ऑब्जेक्ट देता है जिसे लूप का उपयोग करके ट्रैवर्स किया जा सकता है।
from cassandra.cluster import Cluster
clstr=Cluster()
session=clstr.connect('mykeyspace')
rows=session.execute("select * from students;")
for row in rows:
print (StudentID: {} Name:{} Age:{} price:{} Marks:{}'
.format(row[0],row[1], row[2], row[3]))
कैसंड्रा की सेलेक्ट क्वेरी क्वेरी को सेट करने के लिए व्हेयर क्लॉज के उपयोग का समर्थन करती है ताकि परिणाम प्राप्त किया जा सके। पारंपरिक तार्किक संचालक जैसे <,> == आदि को मान्यता दी जाती है। पुनः प्राप्त करने के लिए, छात्रों की तालिका से केवल उन पंक्तियों को जिनकी उम्र> 20 है, निष्पादन में क्वेरी स्ट्रिंग () विधि निम्नानुसार होनी चाहिए -
rows=session.execute("select * from students WHERE age>20 allow filtering;")
ध्यान दें, का उपयोग ALLOW FILTERING। इस कथन का ALL FILTERING भाग स्पष्ट रूप से (कुछ) क्वेरी को फ़िल्टर करने की अनुमति देता है।
कैसेंड्रा ड्राइवर एपीआई अपने कैसेंड्रा.क्वेरी मॉड्यूल में स्टेटमेंट टाइप के निम्नलिखित वर्गों को परिभाषित करता है।
SimpleStatement
एक सरल, बिना तैयारी के CQL क्वेरी क्वेरी स्ट्रिंग में निहित है। ऊपर दिए गए सभी उदाहरण SimpleStatement के उदाहरण हैं।
BatchStatement
एकाधिक प्रश्नों (जैसे INSERT, UPDATE, और DELETE) को एक बैच में रखा जाता है और एक ही बार में निष्पादित किया जाता है। प्रत्येक पंक्ति को पहले एक SimpleStatement के रूप में परिवर्तित किया जाता है और फिर एक बैच में जोड़ा जाता है।
आइए हम छात्रों की तालिका में शामिल की जाने वाली पंक्तियों को निम्न प्रकार के ट्यूल की सूची के रूप में जोड़ते हैं -
studentlist=[(1,'Juhi',20,100), ('2,'dilip',20, 110),(3,'jeevan',24,145)]
BathStatement का उपयोग करके उपरोक्त पंक्तियों को जोड़ने के लिए, स्क्रिप्ट का अनुसरण करें -
from cassandra.query import SimpleStatement, BatchStatement
batch=BatchStatement()
for student in studentlist:
batch.add(SimpleStatement("INSERT INTO students
(studentID, name, age, marks) VALUES
(%s, %s, %s %s)"), (student[0], student[1],student[2], student[3]))
session.execute(batch)
तैयार बयान
तैयार कथन DB-API में एक पैरामीटर की गई क्वेरी की तरह है। इसका क्वेरी स्ट्रिंग बाद में उपयोग के लिए कैसेंड्रा द्वारा सहेजा गया है। Session.prepare () विधि एक रेडीस्टेमेंट उदाहरण देता है।
हमारे छात्रों की तालिका के लिए, INSERT क्वेरी के लिए एक तैयारी स्टैडमेंट इस प्रकार है -
stmt=session.prepare("INSERT INTO students (studentID, name, age, marks) VALUES (?,?,?)")
इसके बाद, इसे केवल मानों को बाँधने के लिए भेजने की आवश्यकता है। उदाहरण के लिए -
qry=stmt.bind([1,'Ram', 23,175])
अंत में, ऊपर दिए गए ब्योरे को निष्पादित करें।
session.execute(qry)
यह नेटवर्क ट्रैफ़िक और CPU उपयोग को कम करता है क्योंकि Cassandra को हर बार क्वेरी को फिर से पार्स नहीं करना पड़ता है।
ZODB (Zope object Database) पायथन वस्तुओं के भंडारण के लिए डेटाबेस है। यह एसीआईडी कंप्लेंट है - यह सुविधा एनओएसक्यूएल डेटाबेस में नहीं मिली है। ZODB भी कई NoSQL डेटाबेस की तरह खुला स्रोत, क्षैतिज रूप से स्केलेबल और स्कीमा-मुक्त है। हालांकि, यह वितरित नहीं है और आसान प्रतिकृति प्रदान नहीं करता है। यह पायथन वस्तुओं के लिए दृढ़ता तंत्र प्रदान करता है। यह ज़ोप एप्लिकेशन सर्वर का एक हिस्सा है, लेकिन इसे स्वतंत्र रूप से भी इस्तेमाल किया जा सकता है।
ZODB को Zope Corporation के जिम फुल्टन ने बनाया था। यह साधारण स्थायी वस्तु प्रणाली के रूप में शुरू हुआ। इसका वर्तमान संस्करण 5.5.0 है और यह पूरी तरह से पायथन में लिखा गया है। पायथन की अंतर्निहित वस्तु दृढ़ता (अचार) के विस्तारित संस्करण का उपयोग करना।
ZODB की कुछ मुख्य विशेषताएं हैं -
- transactions
- history/undo
- पारदर्शी रूप से प्लग करने योग्य भंडारण
- कैशिंग में निर्मित
- मल्टीवर्सन कंसीवेंसी कंट्रोल (MVCC)
- एक नेटवर्क में स्केलेबिलिटी
ZODB एक है hierarchicalडेटाबेस। एक रूट ऑब्जेक्ट है, जब एक डेटाबेस बनाया जाता है तो इनिशियलाइज़ किया जाता है। रूट ऑब्जेक्ट का इस्तेमाल पायथन डिक्शनरी की तरह किया जाता है और इसमें अन्य ऑब्जेक्ट्स (जो खुद डिक्शनरी हो सकते हैं) हो सकते हैं। डेटाबेस में किसी ऑब्जेक्ट को संग्रहीत करने के लिए, इसे अपने कंटेनर के अंदर एक नई कुंजी को असाइन करने के लिए पर्याप्त है।
ZODB उन अनुप्रयोगों के लिए उपयोगी है जहां डेटा पदानुक्रमित है और लिखने की तुलना में अधिक रीड होने की संभावना है। ZODB अचार वस्तु का एक विस्तार है। इसलिए इसे पायथन लिपि के माध्यम से ही संसाधित किया जा सकता है।
ZODB के नवीनतम संस्करण को स्थापित करने के लिए पाइप उपयोगिता का उपयोग करें -
pip install zodb
निम्नलिखित निर्भरताएं भी स्थापित हैं -
- BTrees==4.6.1
- cffi==1.13.2
- persistent==4.5.1
- pycparser==2.19
- six==1.13.0
- transaction==2.4.0
ZODB निम्नलिखित भंडारण विकल्प प्रदान करता है -
फ़ाइल भंडारण
यह डिफ़ॉल्ट है। सब कुछ एक बड़े Data.fs फ़ाइल में संग्रहीत किया जाता है, जो अनिवार्य रूप से एक लेनदेन लॉग है।
DirectoryStorage
यह ऑब्जेक्ट प्रति संशोधन के लिए एक फ़ाइल संग्रहीत करता है। इस स्थिति में, यह अशुद्ध शटडाउन पर Data.fs.index को फिर से बनाने की आवश्यकता नहीं है।
RelStorage
यह एक रिलेशनल डेटाबेस में अचार को स्टोर करता है। PostgreSQL, MySQL और Oracle समर्थित हैं।
ZODB डेटाबेस बनाने के लिए हमें एक स्टोरेज, एक डेटाबेस और अंत में एक कनेक्शन की आवश्यकता होती है।
स्टोरेज ऑब्जेक्ट के लिए पहला कदम है।
import ZODB, ZODB.FileStorage
storage = ZODB.FileStorage.FileStorage('mydata.fs')
डीबी वर्ग डेटाबेस ऑब्जेक्ट को प्राप्त करने के लिए इस स्टोरेज ऑब्जेक्ट का उपयोग करता है।
db = ZODB.DB(storage)
इन-मेमोरी डेटाबेस बनाने के लिए DB कंस्ट्रक्टर के पास कोई नहीं।
Db=ZODB.DB(None)
अंत में, हम डेटाबेस के साथ संबंध स्थापित करते हैं।
conn=db.open()
कनेक्शन ऑब्जेक्ट तब आपको डेटाबेस के 'रूट' को 'रूट ()' विधि से एक्सेस करता है। 'रूट' ऑब्जेक्ट वह डिक्शनरी है जो आपकी सभी स्थायी वस्तुओं को रखती है।
root = conn.root()
उदाहरण के लिए, हम छात्रों की सूची को रूट ऑब्जेक्ट में जोड़ते हैं -
root['students'] = ['Mary', 'Maya', 'Meet']
जब तक हम लेनदेन नहीं करते तब तक यह परिवर्तन डेटाबेस में स्थायी रूप से सहेजा नहीं जाता है।
import transaction
transaction.commit()
उपयोगकर्ता परिभाषित वर्ग की वस्तु को संग्रहीत करने के लिए, वर्ग को स्थायी से अलग होना चाहिए। स्थायी माता-पिता वर्ग।
उपवर्ग के लाभ
उपवर्गीय व्यक्ति के वर्ग के अपने फायदे इस प्रकार हैं -
डेटाबेस स्वचालित रूप से विशेषता सेट करके किए गए ऑब्जेक्ट परिवर्तनों को ट्रैक करेगा।
डेटा को अपने स्वयं के डेटाबेस रिकॉर्ड में सहेजा जाएगा।
आप ऐसे डेटा को सेव कर सकते हैं जो पर्सेंटाइल को उप-वर्ग नहीं करता है, लेकिन इसे डेटाबेस रिकॉर्ड में स्टोर किया जाएगा जो भी लगातार ऑब्जेक्ट का संदर्भ देता है। गैर-स्थिर वस्तुओं का स्वामित्व उनकी स्थिर वस्तु से होता है और यदि कई लगातार वस्तुएं एक ही गैर-स्थिर सबोबेजेक्ट का उल्लेख करती हैं, तो वे अपनी प्रतियां प्राप्त करेंगे।
निम्न के रूप में एक छात्र वर्ग उपवर्गीय कक्षा को परिभाषित करने का उपयोग करें -
import persistent
class student(persistent.Persistent):
def __init__(self, name):
self.name = name
def __repr__(self):
return str(self.name)
इस वर्ग के ऑब्जेक्ट को जोड़ने के लिए, पहले ऊपर दिए गए अनुसार कनेक्शन सेट करें।
import ZODB, ZODB.FileStorage
storage = ZODB.FileStorage.FileStorage('studentdata.fs')
db = ZODB.DB(storage)
conn=db.open()
root = conn.root()
एक ऐड को रूट करने की घोषणा करें और फिर लेनदेन करें
s1=student("Akash")
root['s1']=s1
import transaction
transaction.commit()
conn.close()
रूट में जोड़े गए सभी ऑब्जेक्ट्स की सूची को आइटम () विधि की सहायता से व्यू ऑब्जेक्ट के रूप में प्राप्त किया जा सकता है क्योंकि रूट ऑब्जेक्ट डिक्शनरी में बनाया गया है।
print (root.items())
ItemsView({'s1': Akash})
जड़ से विशिष्ट वस्तु की विशेषता लाने के लिए,
print (root['s1'].name)
Akash
ऑब्जेक्ट को आसानी से अपडेट किया जा सकता है। चूंकि ZODB एपीआई एक शुद्ध पायथन पैकेज है, इसलिए इसे उपयोग करने के लिए किसी बाहरी SQL प्रकार की भाषा की आवश्यकता नहीं होती है।
root['s1'].name='Abhishek'
import transaction
transaction.commit()
डेटाबेस को तुरंत अपडेट किया जाएगा। ध्यान दें कि लेनदेन वर्ग एबोर्ट () फ़ंक्शन को भी परिभाषित करता है जो एसक्यूएल में रोलबैक () लेनदेन नियंत्रण के समान है।
Microsoft का एक्सेल सबसे लोकप्रिय स्प्रेडशीट एप्लिकेशन है। यह पिछले 25 से अधिक वर्षों से उपयोग में है। Excel के बाद के संस्करण उपयोग करते हैंOffice Open XML (OOXML) फ़ाइल स्वरूप। इसलिए, अन्य प्रोग्रामिंग वातावरणों के माध्यम से स्प्रेडशीट फाइलों तक पहुंचना संभव हो गया है।
OOXMLएक ECMA मानक फ़ाइल स्वरूप है। पायथन केopenpyxl पैकेज .xlsx एक्सटेंशन के साथ एक्सेल फाइल को पढ़ने / लिखने के लिए कार्यक्षमता प्रदान करता है।
Openpyxl पैकेज वर्ग नामकरण का उपयोग करता है जो Microsoft Excel शब्दावली के समान है। एक Excel दस्तावेज़ को कार्यपुस्तिका के रूप में कहा जाता है और इसे फ़ाइल सिस्टम में .xlsx एक्सटेंशन के साथ सहेजा जाता है। एक कार्यपुस्तिका में कई कार्यपत्रक हो सकते हैं। एक वर्कशीट कोशिकाओं का एक बड़ा ग्रिड प्रस्तुत करता है, उनमें से प्रत्येक मूल्य या सूत्र को संग्रहीत कर सकता है। ग्रिड बनाने वाले पंक्तियों और स्तंभों को गिना जाता है। कॉलम की पहचान अल्फाबेट्स, ए, बी, सी,…।, जेड, एए, एबी और इसी तरह से की जाती है। पंक्तियों की संख्या 1 से शुरू होती है।
एक विशिष्ट एक्सेल वर्कशीट निम्नानुसार दिखाई देती है -
Openpyxl पैकेज को स्थापित करने के लिए पाइप उपयोगिता काफी अच्छी है।
pip install openpyxl
कार्यपुस्तिका वर्ग एक रिक्त कार्यपुस्तिका के साथ एक रिक्त कार्यपुस्तिका का प्रतिनिधित्व करता है। हमें इसे सक्रिय करने की आवश्यकता है ताकि कुछ डेटा को वर्कशीट में जोड़ा जा सके।
from openpyxl import Workbook
wb=Workbook()
sheet1=wb.active
sheet1.title='StudentList'
जैसा कि हम जानते हैं, वर्कशीट में एक सेल का नाम ColumnNameRownumber प्रारूप है। इस हिसाब से टॉप लेफ्ट सेल A1 है। हम इस सेल को एक स्ट्रिंग प्रदान करते हैं -
sheet1['A1']= 'Student List'
वैकल्पिक रूप से, वर्कशीट का उपयोग करें cell()विधि जो सेल की पहचान करने के लिए पंक्ति और स्तंभ संख्या का उपयोग करती है। वैल्यू असाइन करने के लिए सेल ऑब्जेक्ट को वैल्यू प्रॉपर्टी कहें।
cell1=sheet1.cell(row=1, column=1)
cell1.value='Student List'
कार्यपत्रक को डेटा के साथ आबाद करने के बाद, कार्यपुस्तिका ऑब्जेक्ट की सहेजें () विधि को कॉल करके कार्यपुस्तिका को सहेजा जाता है।
wb.save('Student.xlsx')
यह कार्यपुस्तिका फ़ाइल वर्तमान कार्यशील निर्देशिका में बनाई गई है।
पायथन लिपि के बाद कार्यपुस्तिका के दस्तावेज़ में ट्यूल की सूची लिखता है। प्रत्येक टपल स्टोर में छात्र की संख्या, उम्र और निशान होते हैं।
from openpyxl import Workbook
wb = Workbook()
sheet1 = wb.active
sheet1.title='Student List'
sheet1.cell(column=1, row=1).value='Student List'
studentlist=[('RollNo','Name', 'age', 'marks'),(1,'Juhi',20,100),
(2,'dilip',20, 110) , (3,'jeevan',24,145)]
for col in range(1,5):
for row in range(1,5):
sheet1.cell(column=col, row=1+row).value=studentlist[row-1][col-1]
wb.save('students.xlsx')
कार्यपुस्तिका students.xlsx को वर्तमान कार्य निर्देशिका में सहेजा गया है। यदि एक्सेल एप्लिकेशन का उपयोग करके खोला जाता है, तो यह नीचे दिया गया है -
Openpyxl मॉड्यूल प्रदान करता है load_workbook() फ़ंक्शन जो कार्यपुस्तिका दस्तावेज़ में डेटा वापस पढ़ने में मदद करता है।
from openpyxl import load_workbook
wb=load_workbook('students.xlsx')
अब आप पंक्ति और स्तंभ संख्या द्वारा निर्दिष्ट किसी भी सेल का मान प्राप्त कर सकते हैं।
cell1=sheet1.cell(row=1, column=1)
print (cell1.value)
Student List
उदाहरण
निम्नलिखित कोड कार्य पत्रक डेटा के साथ एक सूची पॉप्युलेट करता है।
from openpyxl import load_workbook
wb=load_workbook('students.xlsx')
sheet1 = wb['Student List']
studentlist=[]
for row in range(1,5):
stud=[]
for col in range(1,5):
val=sheet1.cell(column=col, row=1+row).value
stud.append(val)
studentlist.append(tuple(stud))
print (studentlist)
उत्पादन
[('RollNo', 'Name', 'age', 'marks'), (1, 'Juhi', 20, 100), (2, 'dilip', 20, 110), (3, 'jeevan', 24, 145)]
एक्सेल एप्लिकेशन की एक बहुत महत्वपूर्ण विशेषता सूत्र है। सेल को सूत्र प्रदान करने के लिए, इसे एक्सेल के सूत्र सिंटैक्स वाले स्ट्रिंग में असाइन करें। C6 सेल आयु होने पर AVERAGE फ़ंक्शन असाइन करें।
sheet1['C6']= 'AVERAGE(C3:C5)'
Openpyxl मॉड्यूल है Translate_formula()एक सीमा में सूत्र को कॉपी करने के लिए कार्य करता है। निम्नलिखित कार्यक्रम C6 में AVERAGE फ़ंक्शन को परिभाषित करता है और इसे C7 में कॉपी करता है जो अंकों के औसत की गणना करता है।
from openpyxl import load_workbook
wb=load_workbook('students.xlsx')
sheet1 = wb['Student List']
from openpyxl.formula.translate import Translator#copy formula
sheet1['B6']='Average'
sheet1['C6']='=AVERAGE(C3:C5)'
sheet1['D6'] = Translator('=AVERAGE(C3:C5)', origin="C6").translate_formula("D6")
wb.save('students.xlsx')
अब परिवर्तित वर्कशीट इस प्रकार दिखाई देती है -