पायथन डेटा पर्सिस्टेंस - सीएसवी मॉड्यूल

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'}