पायथन डेटा पर्सिस्टेंस - फाइल एपीआई
पाइथन बिल्ट-इन का उपयोग करता है 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) फ़ाइल के लिए एक स्ट्रिंग लिखता है। कोई रिटर्न वैल्यू नहीं है। |