ऑब्जेक्ट ओरिएंटेड पायथन - ऑब्जेक्ट सीरियलाइज़ेशन
डेटा भंडारण के संदर्भ में, क्रमांकन डेटा संरचनाओं या ऑब्जेक्ट स्थिति को एक प्रारूप में अनुवाद करने की प्रक्रिया है जिसे संग्रहीत किया जा सकता है (उदाहरण के लिए, फ़ाइल या मेमोरी बफर में) या बाद में प्रेषित और पुनर्निर्माण किया जाता है।
क्रमांकन में, एक वस्तु को एक प्रारूप में बदल दिया जाता है, जिसे संग्रहीत किया जा सकता है, ताकि बाद में इसे निष्क्रिय किया जा सके और क्रमबद्ध प्रारूप से मूल वस्तु को फिर से बनाया जा सके।
अचार
अचार बनाना एक ऐसी प्रक्रिया है जिसके तहत एक पायथन ऑब्जेक्ट पदानुक्रम को एक बाइट स्ट्रीम (आमतौर पर मानव पठनीय नहीं) में परिवर्तित किया जाता है जिसे एक फ़ाइल में लिखा जाता है, इसे सीरियलाइज़ेशन भी कहा जाता है। Unpickling एक रिवर्स ऑपरेशन है, जिससे एक बाइट स्ट्रीम वापस काम कर रहे पायथन ऑब्जेक्ट पदानुक्रम में परिवर्तित हो जाती है।
ऑब्जेक्ट को संग्रहीत करने के लिए अचार परिचालन रूप से सबसे सरल तरीका है। पायथन अचार मॉड्यूल एक विशेष भंडारण प्रारूप में वस्तुओं को सीधे स्टोर करने के लिए एक वस्तु-उन्मुख तरीका है।
यह क्या कर सकता है?
- अचार बहुत आसानी से शब्दकोशों और सूचियों को संग्रहीत और पुन: पेश कर सकता है।
- स्टोर ऑब्जेक्ट विशेषताओं और उन्हें उसी राज्य में वापस पुनर्स्थापित करता है।
अचार क्या नहीं कर सकता?
- यह एक ऑब्जेक्ट कोड नहीं बचाता है। केवल यह गुण मान है।
- यह फ़ाइल हैंडल या कनेक्शन सॉकेट स्टोर नहीं कर सकता है।
संक्षेप में हम कह सकते हैं, अचार डेटा वेरिएबल्स को स्टोर करने और पुनः प्राप्त करने का एक तरीका है, फाइलों से जहाँ वेरिएबल को लिस्ट, क्लास आदि किया जा सकता है।
अचार बनाने के लिए आपको कुछ चाहिए -
- आयात अचार
- फाइल करने के लिए एक वैरिएबल, कुछ इस तरह लिखें
pickle.dump(mystring, outfile, protocol),
जहां 3 तर्क प्रोटोकॉल वैकल्पिक है, आपको कुछ अप्रभावित करना चाहिए -
आयात का अचार
एक फ़ाइल में एक चर लिखें, कुछ इस तरह
myString = pickle.load(inputfile)
तरीकों
अचार इंटरफ़ेस चार अलग-अलग तरीके प्रदान करता है।
dump() - डंप () विधि एक खुली फ़ाइल (फ़ाइल जैसी वस्तु) के लिए क्रमबद्ध होती है।
dumps() - एक स्ट्रिंग के लिए सीरियल
load() - एक खुले जैसी वस्तु से वांछित।
loads() - एक स्ट्रिंग से Deserializes।
उपरोक्त प्रक्रिया के आधार पर, नीचे "अचार" का एक उदाहरण है।
उत्पादन
My Cat pussy is White and has 4 legs
Would you like to see her pickled? Here she is!
b'\x80\x03c__main__\nCat\nq\x00)\x81q\x01}q\x02(X\x0e\x00\x00\x00number_of_legsq\x03K\x04X\x05\x00\x00\x00colorq\x04X\x05\x00\x00\x00Whiteq\x05ub.'
इसलिए, ऊपर के उदाहरण में, हमने कैट क्लास का एक उदाहरण बनाया है और फिर हमने इसे "कैट" उदाहरण को बाइट्स के सरल सरणी में बदल दिया है।
इस तरह से हम बाइट्स सरणी को बाइनरी फ़ाइल या डेटाबेस फ़ील्ड में आसानी से संग्रहीत कर सकते हैं और इसे बाद के समय में हमारे भंडारण समर्थन से मूल रूप में वापस ला सकते हैं।
इसके अलावा यदि आप किसी फ़ाइल को किसी ऑब्जेक्ट के साथ बनाना चाहते हैं, तो आप डंप () (डंप्स * () * एक) के बजाय एक ओपन बाइनरी फ़ाइल पास कर सकते हैं और पिकिंग रिजल्ट अपने आप फाइल में स्टोर हो जाएगा।
[….]
binary_file = open(my_pickled_Pussy.bin', mode='wb')
my_pickled_Pussy = pickle.dump(Pussy, binary_file)
binary_file.close()
Unpickling
वह प्रक्रिया जो एक बाइनरी सरणी लेती है और इसे एक वस्तु पदानुक्रम में परिवर्तित करती है, जिसे अनप्लिकिंग कहा जाता है।
अशुद्ध प्रक्रिया अचार मॉड्यूल के लोड () फ़ंक्शन का उपयोग करके की जाती है और एक साधारण बाइट्स सरणी से एक पूरी वस्तु पदानुक्रम देता है।
हमारे पिछले उदाहरण में लोड फ़ंक्शन का उपयोग करते हैं।
उत्पादन
MeOw is black
Pussy is white
JSON
JSON (जावास्क्रिप्ट ऑब्जेक्ट नोटेशन) पायथन मानक पुस्तकालय का हिस्सा रहा है, एक हल्का डेटा-इंटरचेंज प्रारूप है। मनुष्य के लिए पढ़ना और लिखना आसान है। यह पार्स और उत्पन्न करना आसान है।
अपनी सादगी के कारण, JSON एक ऐसा तरीका है जिसके द्वारा हम डेटा स्टोर और एक्सचेंज करते हैं, जो कि इसके JSON सिंटैक्स के माध्यम से पूरा होता है, और कई वेब अनुप्रयोगों में उपयोग किया जाता है। जैसा कि यह मानव पठनीय प्रारूप में है, और यह एपीआई के साथ काम करते समय इसकी प्रभावशीलता के अलावा, डेटा ट्रांसमिशन में इसका उपयोग करने का एक कारण हो सकता है।
JSON-स्वरूपित डेटा का एक उदाहरण निम्नानुसार है -
{"EmployID": 40203, "Name": "Zack", "Age":54, "isEmployed": True}
पायसन ने जोंस फाइलों के साथ काम करना आसान बना दिया है। इस उद्देश्य के लिए उपयोग किया जाने वाला मॉड्यूल JSON मॉड्यूल है। इस मॉड्यूल को आपके पायथन इंस्टॉलेशन के भीतर (बिल्ट-इन) शामिल किया जाना चाहिए।
तो आइए देखें कि हम पायथन डिक्शनरी को JSON में कैसे बदल सकते हैं और इसे टेक्स्ट फाइल में लिख सकते हैं।
JSON to Python
JSON पढ़ने का अर्थ है JSON को एक पायथन मान (ऑब्जेक्ट) में बदलना। जोंस लाइब्रेरी पाइथन में एक शब्दकोश या सूची में JSON को पार्स करती है। ऐसा करने के लिए, हम निम्नानुसार लोड () फ़ंक्शन (एक स्ट्रिंग से लोड) का उपयोग करते हैं, -
उत्पादन
नीचे एक नमूना json फ़ाइल है,
data1.json
{"menu": {
"id": "file",
"value": "File",
"popup": {
"menuitem": [
{"value": "New", "onclick": "CreateNewDoc()"},
{"value": "Open", "onclick": "OpenDoc()"},
{"value": "Close", "onclick": "CloseDoc()"}
]
}
}}
सामग्री से ऊपर (Data1.json) एक पारंपरिक शब्दकोश जैसा दिखता है। हम इस फ़ाइल को संग्रहीत करने के लिए अचार का उपयोग कर सकते हैं लेकिन इसका आउटपुट मानव पठनीय रूप नहीं है।
JSON (Java Script Object Notification) एक बहुत ही सरल प्रारूप है और यही इसकी लोकप्रियता का एक कारण है। अब नीचे प्रोग्राम के माध्यम से json आउटपुट पर नजर डालते हैं।
उत्पादन
ऊपर हम पढ़ने के लिए json फ़ाइल (data1.json) खोलते हैं, फ़ाइल हैंडलर प्राप्त करते हैं और json.load पर जाते हैं और ऑब्जेक्ट वापस प्राप्त करते हैं। जब हम ऑब्जेक्ट के आउटपुट को प्रिंट करने की कोशिश करते हैं, तो यह json फाइल की तरह ही होता है। यद्यपि वस्तु का प्रकार डिक्शनरी है, यह पायथन ऑब्जेक्ट के रूप में सामने आता है। इस अचार को देखने के साथ ही जस्सन को लिखना सरल है। ऊपर हम json फाइल को लोड करते हैं, एक और मुख्य वैल्यू पेयर जोड़ते हैं और इसे उसी json फाइल में लिखते हैं। अब यदि हम data1.json को देखते हैं, तो यह अलग दिखता है। हम पहले जैसा नहीं देखते हैं, उसी स्वरूप में हैं।
हमारे आउटपुट को समान (मानव पठनीय प्रारूप) बनाने के लिए, कार्यक्रम की अंतिम पंक्ति में कुछ दलीलें जोड़ें,
json.dump(conf, fh, indent = 4, separators = (‘,’, ‘: ‘))
इसी प्रकार अचार की तरह, हम डंप के साथ स्ट्रिंग को प्रिंट कर सकते हैं और लोड के साथ लोड कर सकते हैं। नीचे इसका एक उदाहरण है,
YAML
YAML सभी प्रोग्रामिंग भाषाओं के लिए सबसे अधिक मानव अनुकूल डेटा क्रमांकन मानक हो सकता है।
पायथन यम मॉड्यूल को पामल कहा जाता है
YAML JSON का एक विकल्प है -
Human readable code - YAML सबसे अधिक पढ़ने योग्य मानव प्रारूप है, ताकि इस बिंदु को बनाने के लिए इसके फ्रंट पेज की सामग्री भी YAML में प्रदर्शित हो।
Compact code - YAML में हम संरचना नहीं कोष्ठक निरूपित करने के लिए व्हाट्सएप इंडेंटेशन का उपयोग करते हैं।
Syntax for relational data - आंतरिक संदर्भों के लिए हम एंकर (और) और उपनाम (*) का उपयोग करते हैं।
One of the area where it is used widely is for viewing/editing of data structures - उदाहरण के लिए विन्यास फाइल, डिबगिंग और दस्तावेज़ हेडर के दौरान डंपिंग।
YAML स्थापित करना
चूंकि यमल एक अंतर्निहित मॉड्यूल नहीं है, इसलिए हमें इसे मैन्युअल रूप से स्थापित करने की आवश्यकता है। विंडोज़ मशीन पर यम्ल स्थापित करने का सबसे अच्छा तरीका पाइप के माध्यम से है। Yaml को स्थापित करने के लिए अपने विंडोज़ टर्मिनल पर कमांड के नीचे चलाएँ।
pip install pyaml (Windows machine)
sudo pip install pyaml (*nix and Mac)
ऊपर दिए गए आदेश को चलाने पर, स्क्रीन वर्तमान लेटेस्ट वर्जन के आधार पर नीचे की तरह कुछ प्रदर्शित करेगा।
Collecting pyaml
Using cached pyaml-17.12.1-py2.py3-none-any.whl
Collecting PyYAML (from pyaml)
Using cached PyYAML-3.12.tar.gz
Installing collected packages: PyYAML, pyaml
Running setup.py install for PyYAML ... done
Successfully installed PyYAML-3.12 pyaml-17.12.1
इसका परीक्षण करने के लिए, पायथन शेल पर जाएं और yaml मॉड्यूल को आयात करें, yaml को आयात करें, यदि कोई त्रुटि नहीं मिली है, तो हम कह सकते हैं कि स्थापना सफल है।
Pyaml स्थापित करने के बाद, आइए नीचे दिए गए कोड को देखें,
script_yaml1.py
ऊपर हमने तीन अलग-अलग डेटा संरचना, शब्दकोश, सूची और टपल बनाए। प्रत्येक संरचना पर, हम yaml.dump करते हैं। महत्वपूर्ण बिंदु यह है कि स्क्रीन पर आउटपुट कैसे प्रदर्शित किया जाता है।
उत्पादन
शब्दकोश आउटपुट साफ दिखता है। मौलिक मूल्य।
विभिन्न वस्तुओं को अलग करने के लिए सफेद स्थान।
सूची डैश के साथ अंकित है (-)
Tuple को पहले संकेत दिया गया है !! Python / tuple और फिर सूचियों के समान प्रारूप में।
यमल फ़ाइल लोड कर रहा है
तो मान लें कि मेरे पास एक yaml फ़ाइल है, जिसमें शामिल हैं,
---
# An employee record
name: Raagvendra Joshi
job: Developer
skill: Oracle
employed: True
foods:
- Apple
- Orange
- Strawberry
- Mango
languages:
Oracle: Elite
power_builder: Elite
Full Stack Developer: Lame
education:
4 GCSEs
3 A-Levels
MCA in something called com
अब इस yaml फ़ाइल को yaml.load फ़ंक्शन के माध्यम से लोड करने के लिए एक कोड लिखते हैं। नीचे उसी के लिए कोड है।
जैसा कि आउटपुट में इतना पठनीय नहीं दिखता है, मैं अंत में json का उपयोग करके इसे पहले से बता देता हूं। हमें मिले आउटपुट और हमारे पास वास्तविक yaml फ़ाइल की तुलना करें।
उत्पादन
सॉफ्टवेयर विकास का सबसे महत्वपूर्ण पहलू डिबगिंग है। इस भाग में हम पायथन डिबगिंग के अलग-अलग तरीकों को बिल्ट-इन डीबगर या थर्ड पार्टी डीबगर्स के साथ देखेंगे।
पीडीबी - पायथन डीबगर
मॉड्यूल PDB ब्रेकपॉइंट सेट करने का समर्थन करता है। एक ब्रेकपॉइंट प्रोग्राम का एक जानबूझकर विराम है, जहां आप प्रोग्राम स्टेट के बारे में अधिक जानकारी प्राप्त कर सकते हैं।
ब्रेकपॉइंट सेट करने के लिए, लाइन डालें
pdb.set_trace()
उदाहरण
pdb_example1.py
import pdb
x = 9
y = 7
pdb.set_trace()
total = x + y
pdb.set_trace()
हमने इस कार्यक्रम में कुछ विराम बिंदु सम्मिलित किए हैं। कार्यक्रम प्रत्येक ब्रेकपॉइंट (pdb.set_trace ()) पर विराम देगा। एक चर सामग्री देखने के लिए बस चर नाम टाइप करें।
c:\Python\Python361>Python pdb_example1.py
> c:\Python\Python361\pdb_example1.py(8)<module>()
-> total = x + y
(Pdb) x
9
(Pdb) y
7
(Pdb) total
*** NameError: name 'total' is not defined
(Pdb)
प्रेस सी या अगले ब्रेकपॉइंट तक कार्यक्रमों के निष्पादन के साथ आगे बढ़ना जारी रखें।
(Pdb) c
--Return--
> c:\Python\Python361\pdb_example1.py(8)<module>()->None
-> total = x + y
(Pdb) total
16
आखिरकार, आपको बहुत बड़े कार्यक्रमों - सबरूटीन का उपयोग करने वाले कार्यक्रमों को डीबग करना होगा। और कभी-कभी, जिस समस्या को आप खोजने की कोशिश कर रहे हैं, वह सबरूटीन के अंदर होगी। निम्नलिखित कार्यक्रम पर विचार करें।
import pdb
def squar(x, y):
out_squared = x^2 + y^2
return out_squared
if __name__ == "__main__":
#pdb.set_trace()
print (squar(4, 5))
अब उपरोक्त कार्यक्रम चलाने पर,
c:\Python\Python361>Python pdb_example2.py
> c:\Python\Python361\pdb_example2.py(10)<module>()
-> print (squar(4, 5))
(Pdb)
हम प्रयोग कर सकते हैं ?सहायता प्राप्त करने के लिए, लेकिन तीर उस रेखा को इंगित करता है जो निष्पादित होने वाली है। इस बिंदु पर यह एस हिट करने के लिए उपयोगी हैs उस लाइन में कदम रखने के लिए।
(Pdb) s
--Call--
>c:\Python\Python361\pdb_example2.py(3)squar()
-> def squar(x, y):
यह एक फ़ंक्शन के लिए एक कॉल है। यदि आप अपने कोड में कहाँ हैं, का अवलोकन चाहते हैं, तो l की कोशिश करें -
(Pdb) l
1 import pdb
2
3 def squar(x, y):
4 -> out_squared = x^2 + y^2
5
6 return out_squared
7
8 if __name__ == "__main__":
9 pdb.set_trace()
10 print (squar(4, 5))
[EOF]
(Pdb)
आप अगली पंक्ति के लिए अग्रिम करने के लिए n हिट कर सकते हैं। इस बिंदु पर आप out_squared पद्धति के अंदर हैं और आपके पास फ़ंक्शन .ie x और y के अंदर घोषित चर तक पहुंच है।
(Pdb) x
4
(Pdb) y
5
(Pdb) x^2
6
(Pdb) y^2
7
(Pdb) x**2
16
(Pdb) y**2
25
(Pdb)
तो हम देख सकते हैं ^ ऑपरेटर नहीं है जो हम चाहते थे इसके बजाय हमें ** ऑपरेटर का उपयोग करने की आवश्यकता है वर्गों को करने के लिए।
इस तरह हम फ़ंक्शन / विधियों के अंदर अपने प्रोग्राम को डीबग कर सकते हैं।
लॉगिंग
लॉगिंग मॉड्यूल पायथन संस्करण 2.3 के बाद से पायथन के मानक पुस्तकालय का एक हिस्सा रहा है। जैसा कि यह एक बिल्ट-इन मॉड्यूल है, सभी पायथन मॉड्यूल लॉगिंग में भाग ले सकते हैं, ताकि हमारे एप्लिकेशन लॉग में थर्ड पार्टी मॉड्यूल के संदेशों के साथ एकीकृत आपका अपना संदेश शामिल हो सके। यह बहुत अधिक लचीलापन और कार्यक्षमता प्रदान करता है।
लॉगिंग के लाभ
Diagnostic logging - यह एप्लिकेशन के ऑपरेशन से संबंधित घटनाओं को रिकॉर्ड करता है।
Audit logging - यह व्यापार विश्लेषण के लिए घटनाओं को रिकॉर्ड करता है।
संदेश "गंभीरता" और मीनू के स्तरों पर लिखे और लॉग किए गए हैं
DEBUG (debug()) - विकास के लिए नैदानिक संदेश।
INFO (info()) - मानक "प्रगति" संदेश।
WARNING (warning()) - एक गैर-गंभीर मुद्दे का पता चला।
ERROR (error()) - संभवतः एक त्रुटि हुई, गंभीर।
CRITICAL (critical()) - आमतौर पर एक घातक त्रुटि (कार्यक्रम बंद हो जाता है)।
आइए नीचे सरल कार्यक्रम में देखें,
import logging
logging.basicConfig(level=logging.INFO)
logging.debug('this message will be ignored') # This will not print
logging.info('This should be logged') # it'll print
logging.warning('And this, too') # It'll print
ऊपर हम गंभीरता स्तर पर संदेश लॉग कर रहे हैं। पहले हम मॉड्यूल को आयात करते हैं, बेसिकफोन को कॉल करते हैं और लॉगिंग स्तर सेट करते हैं। स्तर हम ऊपर सेट है जानकारी है। फिर हमारे पास तीन अलग-अलग कथन हैं: डिबग स्टेटमेंट, सूचना स्टेटमेंट और एक चेतावनी स्टेटमेंट।
Logging1.py का आउटपुट
INFO:root:This should be logged
WARNING:root:And this, too
जैसा कि जानकारी विवरण डीबग कथन के नीचे है, हम डिबग संदेश देखने में सक्षम नहीं हैं। डिबग स्टेटमेंट को आउटपुट टर्मिनल में भी प्राप्त करने के लिए, हम सभी को बदलने की जरूरत है बुनियादी स्तर है।
logging.basicConfig(level = logging.DEBUG)
और आउटपुट में हम देख सकते हैं,
DEBUG:root:this message will be ignored
INFO:root:This should be logged
WARNING:root:And this, too
साथ ही डिफ़ॉल्ट व्यवहार का अर्थ है यदि हम कोई लॉगिंग स्तर सेट नहीं करते हैं तो चेतावनी है। बस उपरोक्त कार्यक्रम से दूसरी पंक्ति पर टिप्पणी करें और कोड चलाएं।
#logging.basicConfig(level = logging.DEBUG)
उत्पादन
WARNING:root:And this, too
लॉगिंग स्तर में निर्मित पायथन वास्तव में पूर्णांक हैं।
>>> import logging
>>>
>>> logging.DEBUG
10
>>> logging.CRITICAL
50
>>> logging.WARNING
30
>>> logging.INFO
20
>>> logging.ERROR
40
>>>
हम फ़ाइल में लॉग संदेशों को भी सहेज सकते हैं।
logging.basicConfig(level = logging.DEBUG, filename = 'logging.log')
अब सभी लॉग संदेश फ़ाइल (logging.log) स्क्रीन के बजाय आपकी वर्तमान कार्यशील निर्देशिका में जाएंगे। यह एक बेहतर तरीका है क्योंकि यह हमें उन संदेशों का पोस्ट विश्लेषण करने देता है जो हमें मिले थे।
हम अपने लॉग संदेश के साथ दिनांक मोहर भी लगा सकते हैं।
logging.basicConfig(level=logging.DEBUG, format = '%(asctime)s %(levelname)s:%(message)s')
आउटपुट कुछ ऐसा मिलेगा,
2018-03-08 19:30:00,066 DEBUG:this message will be ignored
2018-03-08 19:30:00,176 INFO:This should be logged
2018-03-08 19:30:00,201 WARNING:And this, too
बेंच मार्किंग
बेंचमार्किंग या प्रोफाइलिंग मूल रूप से यह परीक्षण करने के लिए है कि आपका कोड कितनी तेजी से निष्पादित होता है और अड़चनें कहां हैं? ऐसा करने का मुख्य कारण अनुकूलन के लिए है।
timeit
पायथन एक इन-बिल्ट मॉड्यूल के साथ आता है जिसे टाइमिट कहा जाता है। आप समय-समय पर छोटे कोड स्निपेट का उपयोग कर सकते हैं। टाइमटाइम मॉड्यूल प्लेटफ़ॉर्म-विशिष्ट टाइम फ़ंक्शंस का उपयोग करता है ताकि आपको सबसे सटीक समय मिल सके।
इसलिए, यह हमें प्रत्येक द्वारा लिए गए कोड के दो शिपमेंट की तुलना करने की अनुमति देता है और फिर बेहतर प्रदर्शन के लिए स्क्रिप्ट का अनुकूलन करता है।
टाइमटाइम मॉड्यूल में कमांड लाइन इंटरफ़ेस है, लेकिन इसे आयात भी किया जा सकता है।
स्क्रिप्ट को कॉल करने के दो तरीके हैं। आइए पहले स्क्रिप्ट का उपयोग करें, इसके लिए नीचे दिए गए कोड को चलाएं और आउटपुट देखें।
import timeit
print ( 'by index: ', timeit.timeit(stmt = "mydict['c']", setup = "mydict = {'a':5, 'b':10, 'c':15}", number = 1000000))
print ( 'by get: ', timeit.timeit(stmt = 'mydict.get("c")', setup = 'mydict = {"a":5, "b":10, "c":15}', number = 1000000))
उत्पादन
by index: 0.1809192126703489
by get: 0.6088525265034692
ऊपर हम दो अलग-अलग विधि का उपयोग करते हैं। सबस्क्रिप्ट द्वारा और शब्दकोश कुंजी मूल्य तक पहुंचने के लिए। हम 1 मिलियन बार स्टेटमेंट निष्पादित करते हैं क्योंकि यह बहुत छोटे डेटा के लिए बहुत तेज़ी से निष्पादित होता है। अब हम प्राप्त की तुलना में सूचकांक की पहुंच को बहुत तेजी से देख सकते हैं। हम कोड को कई बार चला सकते हैं और बेहतर समझ पाने के लिए समय निष्पादन में थोड़ा बदलाव होगा।
एक और तरीका है कमांड लाइन में उपरोक्त परीक्षण को चलाना। हो जाए,
c:\Python\Python361>Python -m timeit -n 1000000 -s "mydict = {'a': 5, 'b':10, 'c':15}" "mydict['c']"
1000000 loops, best of 3: 0.187 usec per loop
c:\Python\Python361>Python -m timeit -n 1000000 -s "mydict = {'a': 5, 'b':10, 'c':15}" "mydict.get('c')"
1000000 loops, best of 3: 0.659 usec per loop
उपरोक्त आउटपुट आपके सिस्टम हार्डवेयर के आधार पर भिन्न हो सकते हैं और वर्तमान में आपके सिस्टम में सभी एप्लिकेशन चल रहे हैं।
नीचे हम टाइमटाइम मॉड्यूल का उपयोग कर सकते हैं, अगर हम किसी फ़ंक्शन को कॉल करना चाहते हैं। जैसा कि हम परीक्षण करने के लिए फ़ंक्शन के अंदर कई कथन जोड़ सकते हैं।
import timeit
def testme(this_dict, key):
return this_dict[key]
print (timeit.timeit("testme(mydict, key)", setup = "from __main__ import testme; mydict = {'a':9, 'b':18, 'c':27}; key = 'c'", number = 1000000))
उत्पादन
0.7713474590139164