ऑब्जेक्ट ओरिएंटेड पायथन - बिल्डिंग ब्लॉक्स
इस अध्याय में, हम ऑब्जेक्ट ओरिएंटेड टर्म्स और प्रोग्रामिंग कॉन्सेप्ट्स पर विस्तार से चर्चा करेंगे। क्लैस एक उदाहरण के लिए सिर्फ एक फैक्ट्री है। इस कारखाने में ब्लूप्रिंट होता है जो बताता है कि कैसे उदाहरणों को बनाना है। एक उदाहरण या वस्तु का निर्माण वर्ग से किया जाता है। ज्यादातर मामलों में, हम एक वर्ग के एक से अधिक उदाहरण हो सकते हैं। हर उदाहरण में विशेषता का एक समूह होता है और इन विशेषताओं को एक वर्ग में परिभाषित किया जाता है, इसलिए किसी विशेष वर्ग के प्रत्येक उदाहरण में समान गुण होने की अपेक्षा की जाती है।
क्लास बंडल्स: व्यवहार और राज्य
एक वर्ग आपको एक वस्तु के व्यवहार और स्थिति को एक साथ बंडल करने देगा। बेहतर समझ के लिए निम्नलिखित चित्र का अवलोकन करें -
वर्ग बंडलों की चर्चा करते समय निम्नलिखित बिंदु उल्लेखनीय हैं -
शब्द behavior के समान है function - यह कोड का एक टुकड़ा है जो कुछ करता है (या एक व्यवहार को लागू करता है)
शब्द state के समान है variables - यह एक वर्ग के भीतर मूल्यों को संग्रहीत करने के लिए एक जगह है।
जब हम एक वर्ग व्यवहार और एक साथ राज्य का दावा करते हैं, तो इसका मतलब है कि एक वर्ग कार्य करता है और चर।
कक्षाओं में विधियाँ और विशेषताएँ होती हैं
पायथन में, एक विधि का निर्माण एक वर्ग व्यवहार को परिभाषित करता है। शब्द विधि एक फ़ंक्शन को दिया गया OOP नाम है जिसे एक वर्ग के भीतर परिभाषित किया गया है। योग करने के लिए -
Class functions - का पर्यायवाची है methods
Class variables - का पर्यायवाची है name attributes.
Class - सटीक व्यवहार के साथ एक उदाहरण के लिए एक खाका।
Object - कक्षा के उदाहरणों में से एक, कक्षा में परिभाषित कार्यक्षमता का प्रदर्शन करना।
Type संकेत करता है कि वह वर्ग किस वर्ग का है
Attribute - किसी भी वस्तु का मूल्य: वस्तु
Method - क्लास में परिभाषित एक "कॉल करने योग्य विशेषता"
उदाहरण के लिए निम्नलिखित कोड कोड देखें -
var = “Hello, John”
print( type (var)) # ‘str’> or <class 'str'>
print(var.upper()) # upper() method is called, HELLO, JOHN
निर्माण और त्वरित
निम्न कोड दिखाता है कि हमारी पहली कक्षा और फिर उसका उदाहरण कैसे बनाया जाए।
class MyClass(object):
pass
# Create first instance of MyClass
this_obj = MyClass()
print(this_obj)
# Another instance of MyClass
that_obj = MyClass()
print (that_obj)
यहाँ हमने एक क्लास बनाई है जिसका नाम है MyClassऔर जो कोई कार्य नहीं करता है। बहसobject में MyClass क्लास में क्लास इनहेरिटेंस शामिल है और बाद के अध्यायों में चर्चा की जाएगी। pass उपरोक्त कोड में इंगित किया गया है कि यह ब्लॉक खाली है, अर्थात यह एक खाली वर्ग की परिभाषा है।
एक उदाहरण बनाते हैं this_obj का MyClass() कक्षा और दिखाए अनुसार प्रिंट करें -
<__main__.MyClass object at 0x03B08E10>
<__main__.MyClass object at 0x0369D390>
यहाँ, हमने एक उदाहरण बनाया है MyClass.हेक्स कोड उस पते को संदर्भित करता है जहां ऑब्जेक्ट संग्रहीत किया जा रहा है। एक अन्य उदाहरण दूसरे पते की ओर इशारा कर रहा है।
अब हम कक्षा के अंदर एक चर को परिभाषित करते हैं MyClass() और निम्न कोड में दिखाए अनुसार उस वर्ग के उदाहरण से चर प्राप्त करें -
class MyClass(object):
var = 9
# Create first instance of MyClass
this_obj = MyClass()
print(this_obj.var)
# Another instance of MyClass
that_obj = MyClass()
print (that_obj.var)
उत्पादन
जब आप ऊपर दिए गए कोड को निष्पादित करते हैं तो आप निम्नलिखित आउटपुट देख सकते हैं -
9
9
जैसे कि उदाहरण से पता चलता है कि यह किस वर्ग से तात्कालिक है, इसलिए जब किसी उदाहरण से विशेषता के लिए अनुरोध किया जाता है, तो उदाहरण विशेषता और वर्ग के लिए दिखता है। इसे कहते हैंattribute lookup.
उदाहरण के तरीके
एक वर्ग में परिभाषित एक फ़ंक्शन को कहा जाता है method.एक आवृत्ति विधि को कॉल करने के लिए एक उदाहरण की आवश्यकता होती है और किसी डेकोरेटर की आवश्यकता नहीं होती है। एक आवृत्ति विधि बनाते समय, पहला पैरामीटर हमेशा होता हैself. हालांकि हम इसे (स्वयं) किसी अन्य नाम से बुला सकते हैं, यह स्वयं का उपयोग करने की सिफारिश की जाती है, क्योंकि यह एक नामकरण सम्मेलन है।
class MyClass(object):
var = 9
def firstM(self):
print("hello, World")
obj = MyClass()
print(obj.var)
obj.firstM()
उत्पादन
जब आप ऊपर दिए गए कोड को निष्पादित करते हैं तो आप निम्नलिखित आउटपुट देख सकते हैं -
9
hello, World
ध्यान दें कि उपरोक्त कार्यक्रम में, हमने एक विधि को तर्क के रूप में परिभाषित किया है। लेकिन हम इस पद्धति को नहीं कह सकते क्योंकि हमने इसके लिए कोई तर्क नहीं दिया है।
class MyClass(object):
def firstM(self):
print("hello, World")
print(self)
obj = MyClass()
obj.firstM()
print(obj)
उत्पादन
जब आप ऊपर दिए गए कोड को निष्पादित करते हैं तो आप निम्नलिखित आउटपुट देख सकते हैं -
hello, World
<__main__.MyClass object at 0x036A8E10>
<__main__.MyClass object at 0x036A8E10>
कैप्सूलीकरण
इनकैप्सुलेशन ओओपी के मूल सिद्धांतों में से एक है। OOP हमें ऑब्जेक्ट के आंतरिक कार्य की जटिलता को छिपाने में सक्षम बनाता है जो निम्नलिखित तरीकों से डेवलपर के लिए फायदेमंद है -
सरलीकृत करता है और आंतरिक को जानने के बिना किसी वस्तु का उपयोग करना समझना आसान बनाता है।
किसी भी परिवर्तन को आसानी से प्रबंधित किया जा सकता है।
ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग एनकैप्सुलेशन पर बहुत निर्भर करता है। शब्द एन्कैप्सुलेशन और एब्स्ट्रैक्शन (जिसे डेटा छिपाना भी कहा जाता है) को अक्सर समानार्थक शब्द के रूप में उपयोग किया जाता है। वे लगभग पर्यायवाची हैं, क्योंकि अतिक्रमण encapsulation के माध्यम से प्राप्त किया जाता है।
एनकैप्सुलेशन हमें ऑब्जेक्ट के कुछ घटकों तक पहुंच को प्रतिबंधित करने का तंत्र प्रदान करता है, इसका मतलब है कि ऑब्जेक्ट की आंतरिक परिभाषा को ऑब्जेक्ट परिभाषा के बाहर से नहीं देखा जा सकता है। इस डेटा तक पहुंच आम तौर पर विशेष तरीकों से हासिल की जाती है -Getters तथा Setters.
यह डेटा इंस्टेंस विशेषताओं में संग्रहीत है और इसे क्लास के बाहर कहीं से भी हेरफेर किया जा सकता है। इसे सुरक्षित करने के लिए, उस डेटा को केवल इंस्टेंस विधियों का उपयोग करके एक्सेस किया जाना चाहिए। प्रत्यक्ष पहुंच की अनुमति नहीं दी जानी चाहिए।
class MyClass(object):
def setAge(self, num):
self.age = num
def getAge(self):
return self.age
zack = MyClass()
zack.setAge(45)
print(zack.getAge())
zack.setAge("Fourty Five")
print(zack.getAge())
उत्पादन
जब आप ऊपर दिए गए कोड को निष्पादित करते हैं तो आप निम्नलिखित आउटपुट देख सकते हैं -
45
Fourty Five
डेटा को केवल तभी संग्रहीत किया जाना चाहिए यदि यह सही और मान्य है, अपवाद हैंडलिंग निर्माण का उपयोग करते हुए। जैसा कि हम ऊपर देख सकते हैं, उपयोगकर्ता इनपुट टू सेटएज () पद्धति पर कोई प्रतिबंध नहीं है। यह एक स्ट्रिंग, एक संख्या, या एक सूची हो सकती है। इसलिए हमें स्टोर किए जाने की शुद्धता सुनिश्चित करने के लिए उपरोक्त कोड की जांच करने की आवश्यकता है।
class MyClass(object):
def setAge(self, num):
self.age = num
def getAge(self):
return self.age
zack = MyClass()
zack.setAge(45)
print(zack.getAge())
zack.setAge("Fourty Five")
print(zack.getAge())
Init कंस्ट्रक्टर
__init__ विधि को किसी वर्ग की वस्तु के रूप में जल्द से जल्द कहा जाता है। यह ऑब्जेक्ट को इनिशियलाइज़ करेगा।
x = MyClass()
ऊपर दिखाई गई कोड की लाइन एक नया उदाहरण बनाएगी और इस ऑब्जेक्ट को स्थानीय चर x पर असाइन करेगी।
तात्कालिक संचालन, जो है calling a class objectएक खाली वस्तु बनाता है। कई वर्ग एक विशिष्ट प्रारंभिक अवस्था में अनुकूलित उदाहरणों के साथ ऑब्जेक्ट बनाना पसंद करते हैं। इसलिए, एक वर्ग एक विशेष विधि को परिभाषित कर सकता है, जिसका नाम '__init__' () 'दिखाया गया है -
def __init__(self):
self.data = []
पायथन ने एक अतिरिक्त विशेषता को परिभाषित करने के लिए तात्कालिकता के दौरान __init__ को कॉल किया जो तब होता है जब एक वर्ग को त्वरित किया जाता है जो उस वस्तु के लिए कुछ शुरुआत मान स्थापित कर सकता है या तात्कालिकता पर आवश्यक दिनचर्या चला सकता है। तो इस उदाहरण में, एक नया, प्रारंभिक उदाहरण प्राप्त किया जा सकता है -
x = MyClass()
__Init __ () विधि में अधिक लचीलेपन के लिए एकल या एकाधिक तर्क हो सकते हैं। यह init इनिशियलाइज़ेशन के लिए खड़ा है, क्योंकि यह उदाहरण की विशेषताओं को इनिशियलाइज़ करता है। इसे क्लास का कंस्ट्रक्टर कहा जाता है।
class myclass(object):
def __init__(self,aaa, bbb):
self.a = aaa
self.b = bbb
x = myclass(4.5, 3)
print(x.a, x.b)
उत्पादन
4.5 3
वर्ग गुण
वर्ग में परिभाषित विशेषता को "वर्ग गुण" कहा जाता है और फ़ंक्शन में परिभाषित विशेषताओं को 'उदाहरण विशेषताएँ' कहा जाता है। परिभाषित करते समय, ये विशेषताएँ स्वयं द्वारा उपसर्ग नहीं की जाती हैं, क्योंकि ये वर्ग की संपत्ति हैं और किसी विशेष उदाहरण की नहीं।
वर्ग की विशेषताओं को वर्ग (className.attributeName) के साथ-साथ वर्ग के उदाहरणों (inst.attributeName) तक पहुँचा जा सकता है। तो, इंस्टेंसेस में दोनों इंस्टेंस विशेषता के साथ-साथ क्लास एट्रीब्यूट्स तक पहुंच होती है।
>>> class myclass():
age = 21
>>> myclass.age
21
>>> x = myclass()
>>> x.age
21
>>>
एक वर्ग विशेषता को एक उदाहरण में ओवरराइड किया जा सकता है, भले ही यह एनकैप्सुलेशन को तोड़ने के लिए एक अच्छी विधि नहीं है।
पायथन में विशेषताओं के लिए एक खोज पथ है। पहले वर्ग के भीतर परिभाषित विधि, और फिर इसके ऊपर की कक्षा।
>>> class myclass(object):
classy = 'class value'
>>> dd = myclass()
>>> print (dd.classy) # This should return the string 'class value'
class value
>>>
>>> dd.classy = "Instance Value"
>>> print(dd.classy) # Return the string "Instance Value"
Instance Value
>>>
>>> # This will delete the value set for 'dd.classy' in the instance.
>>> del dd.classy
>>> >>> # Since the overriding attribute was deleted, this will print 'class
value'.
>>> print(dd.classy)
class value
>>>
हम उदाहरण dd में 'उत्तम दर्जे' वर्ग विशेषता से आगे निकल रहे हैं। जब यह ओवरराइड हो जाता है, तो पायथन इंटरप्रिटर ओवरराइड वैल्यू पढ़ता है। लेकिन एक बार जब नया मान 'डेल' के साथ हटा दिया जाता है, तो ओवरराइड वैल्यू अब उदाहरण में मौजूद नहीं है, और इसलिए लुकअप ऊपर के स्तर पर जाता है और इसे कक्षा से प्राप्त करता है।
क्लास और इंस्टेंस डेटा के साथ काम करना
इस खंड में, हम समझते हैं कि वर्ग डेटा उदाहरण डेटा से कैसे संबंधित है। हम डेटा को कक्षा में या उदाहरण में संग्रहीत कर सकते हैं। जब हम एक वर्ग डिज़ाइन करते हैं, तो हम तय करते हैं कि कौन सा डेटा उदाहरण के लिए है और कौन सा डेटा समग्र वर्ग में संग्रहीत किया जाना चाहिए।
एक उदाहरण वर्ग डेटा तक पहुँच सकता है। यदि हम कई उदाहरण बनाते हैं, तो ये उदाहरण उनके व्यक्तिगत विशेषता मानों के साथ-साथ समग्र श्रेणी के डेटा तक पहुंच सकते हैं।
इस प्रकार, एक वर्ग डेटा वह डेटा है जो सभी उदाहरणों के बीच साझा किया जाता है। बेहतर अंडरस्कोरिंग के लिए नीचे दिए गए कोड को ध्यान से देखें -
class InstanceCounter(object):
count = 0 # class attribute, will be accessible to all instances
def __init__(self, val):
self.val = val
InstanceCounter.count +=1 # Increment the value of class attribute, accessible through class name
# In above line, class ('InstanceCounter') act as an object
def set_val(self, newval):
self.val = newval
def get_val(self):
return self.val
def get_count(self):
return InstanceCounter.count
a = InstanceCounter(9)
b = InstanceCounter(18)
c = InstanceCounter(27)
for obj in (a, b, c):
print ('val of obj: %s' %(obj.get_val())) # Initialized value ( 9, 18, 27)
print ('count: %s' %(obj.get_count())) # always 3
उत्पादन
val of obj: 9
count: 3
val of obj: 18
count: 3
val of obj: 27
count: 3
संक्षेप में, वर्ग की विशेषताएँ कक्षा के सभी उदाहरणों के लिए समान होती हैं जबकि उदाहरण विशेषताएँ प्रत्येक उदाहरण के लिए विशेष रूप से होती हैं। दो अलग-अलग उदाहरणों के लिए, हमारे पास दो अलग-अलग उदाहरण विशेषताएँ होंगी।
class myClass:
class_attribute = 99
def class_method(self):
self.instance_attribute = 'I am instance attribute'
print (myClass.__dict__)
उत्पादन
जब आप ऊपर दिए गए कोड को निष्पादित करते हैं तो आप निम्नलिखित आउटपुट देख सकते हैं -
{'__module__': '__main__', 'class_attribute': 99, 'class_method':
, '__dict__':
, '__weakref__':
, '__doc__': None}
The instance attribute myClass.__dict__ as shown −
>>> a = myClass()
>>> a.class_method()
>>> print(a.__dict__)
{'instance_attribute': 'I am instance attribute'}