course

फ़ंक्शन्स Python प्रोग्रामिंग भाषा का एक अनिवार्य हिस्सा हैं: संभव है कि आपने पहले ही Python भाषा में मौजूद कई बेहतरीन बिल्ट-इन फ़ंक्शन्स का या इसकी लाइब्रेरी इकोसिस्टम के साथ आने वाले फ़ंक्शन्स का उपयोग किया हो। फिर भी, एक डेटा वैज्ञानिक के रूप में, आपको अपने डेटा से उत्पन्न समस्याओं को हल करने के लिए बार-बार अपने स्वयं के फ़ंक्शन्स लिखने होंगे।
यह ट्यूटोरियल Python 3 सिंटैक्स का उपयोग करता है। सभी उदाहरण Python 3.10+ पर काम करते हैं और आधुनिक कन्वेंशन्स (f-strings, type hints, positional-only और keyword-only पैरामीटर्स) को प्रतिबिंबित करने के लिए अपडेट किए गए हैं। मौजूदा स्थिर रिलीज Python 3.14 है।
इस ट्यूटोरियल के सभी उदाहरण कोड को खुद आसानी से चलाने के लिए, आप मुफ़्त में एक DataLab वर्कबुक बना सकते हैं, जिसमें Python पहले से इंस्टॉल होता है और सभी कोड सैंपल शामिल होते हैं। Python फ़ंक्शन्स लिखने का और अभ्यास करने के लिए, यह हैंड्स-ऑन DataCamp अभ्यास देखें या हमारा Python Data Science Toolbox कोर्स आज़माएँ!
Python में फ़ंक्शन्स
प्रोग्रामिंग में आप फ़ंक्शन्स का उपयोग निर्देशों के ऐसे सेट को एक साथ बांधने के लिए करते हैं जिन्हें आप बार-बार उपयोग करना चाहते हैं या जो अपनी जटिलता के कारण किसी सब-प्रोग्राम में अलग रखना बेहतर होता है और ज़रूरत पड़ने पर कॉल किया जाता है। इसका मतलब है कि कोई फ़ंक्शन एक विशेष कार्य को करने के लिए लिखा गया कोड का टुकड़ा है। उस विशेष कार्य को करने के लिए, फ़ंक्शन को एक या अधिक इनपुट चाहिए हो सकते हैं या नहीं भी। और जब कार्य पूरा हो जाता है, तो फ़ंक्शन एक या एक से अधिक वैल्यू लौटाएगा या नहीं भी लौटा सकता है।
Python में फ़ंक्शन्स के तीन प्रकार होते हैं:
-
बिल्ट-इन फ़ंक्शन्स, जैसे
help()मदद के लिए,min()न्यूनतम मान पाने के लिए,print()किसी ऑब्जेक्ट को टर्मिनल पर प्रिंट करने के लिए,… इन फ़ंक्शन्स का और अवलोकन आप यहाँ पा सकते हैं। -
यूज़र-डिफ़ाइन्ड फ़ंक्शन्स (UDFs), जो उपयोगकर्ता अपनी ज़रूरत के अनुसार बनाते हैं; और
-
गुमनाम फ़ंक्शन्स, जिन्हें lambda फ़ंक्शन्स भी कहा जाता है क्योंकि इन्हें मानक
defकीवर्ड से घोषित नहीं किया जाता।
फ़ंक्शन्स बनाम मेथड्स
मेथड किसी क्लास का हिस्सा होने वाला फ़ंक्शन होता है। आप इसे उस क्लास के किसी इंस्टेंस या ऑब्जेक्ट से एक्सेस करते हैं। फ़ंक्शन पर यह पाबंदी नहीं होती: यह एक स्टैंडअलोन फ़ंक्शन होता है। यानी, सभी मेथड्स फ़ंक्शन्स हैं, लेकिन सभी फ़ंक्शन्स मेथड्स नहीं होते।
यह उदाहरण देखें, जहाँ आप पहले plus() नाम का फ़ंक्शन परिभाषित करते हैं और फिर Summation क्लास जिसमें sum() मेथड है:
अब अगर आप Summation क्लास के हिस्से sum() मेथड को कॉल करना चाहते हैं, तो पहले आपको उस क्लास का एक इंस्टेंस या ऑब्जेक्ट बनाना होगा। तो, ऐसा एक ऑब्जेक्ट परिभाषित करते हैं:
याद रखें कि plus() फ़ंक्शन को कॉल करने के लिए यह इंस्टैंशिएशन ज़रूरी नहीं है! आप DataCamp Light कोड चंक में बिना किसी समस्या के plus(1,2) चला पाएँगे!
पैरामीटर्स बनाम आर्ग्युमेंट्स
पैरामीटर्स वे नाम हैं जो किसी फ़ंक्शन या मेथड को परिभाषित करते समय दिए जाते हैं, और जिनमें आर्ग्युमेंट्स मैप होते हैं। दूसरे शब्दों में, आर्ग्युमेंट्स वे मान होते हैं जो किसी फ़ंक्शन या मेथड कॉल को दिए जाते हैं, जबकि फ़ंक्शन या मेथड का कोड इन आर्ग्युमेंट्स को उनके पैरामीटर नामों से संदर्भित करता है।
यह उदाहरण देखें और ऊपर दिए गए DataCamp Light चंक को याद करें: आप Summation क्लास के sum() मेथड को दो आर्ग्युमेंट्स पास करते हैं, जबकि आपने पहले तीन पैरामीटर्स परिभाषित किए थे: self, a और b।
self का क्या हुआ?
हर क्लास मेथड का पहला आर्ग्युमेंट हमेशा उस क्लास के मौजूदा इंस्टेंस का रेफ़रन्स होता है, जो इस मामले में Summation है। परंपरा के अनुसार, इस आर्ग्युमेंट को self कहा जाता है।
इसका मतलब यह है कि इस मामले में आप self का रेफ़रन्स पास नहीं करते, क्योंकि self वह पैरामीटर नाम है जिसके लिए आर्ग्युमेंट इम्प्लिसिटली पास होता है और उस इंस्टेंस को संदर्भित करता है जिसके माध्यम से मेथड को इनवोक किया जा रहा है। यह आर्ग्युमेंट सूची में स्वतः जोड़ा जाता है।
फ़ंक्शन कैसे परिभाषित करें: यूज़र-डिफ़ाइन्ड फ़ंक्शन्स (UDFs)
Python में फ़ंक्शन परिभाषित करने के चार चरण इस प्रकार हैं:
-
फ़ंक्शन घोषित करने के लिए
defकीवर्ड का उपयोग करें और इसके बाद फ़ंक्शन का नाम लिखें। -
फ़ंक्शन में पैरामीटर्स जोड़ें: वे फ़ंक्शन की कोष्ठकों में होने चाहिए। अपनी लाइन को कॉलन के साथ समाप्त करें।
-
वे स्टेटमेंट्स जोड़ें जिन्हें फ़ंक्शन को निष्पादित करना चाहिए।
-
यदि फ़ंक्शन को कुछ आउटपुट देना चाहिए तो उसे return स्टेटमेंट के साथ समाप्त करें। बिना return स्टेटमेंट के, आपका फ़ंक्शन
Noneऑब्जेक्ट लौटाएगा।
बेशक, जैसे-जैसे आप आगे बढ़ेंगे, आपके फ़ंक्शन्स और जटिल होते जाएँगे: आप इसमें for लूप, फ़्लो कंट्रोल, … आदि जोड़कर इसे और सूक्ष्म बना सकते हैं:
def hello():
name = input("Enter your name: ")
if name:
print(f"Hello {name}")
else:
print("Hello World")
hello()
ऊपर वाले फ़ंक्शन में, आप यूज़र से नाम देने के लिए कहते हैं। अगर नाम नहीं दिया गया, तो फ़ंक्शन “Hello World” प्रिंट करेगा। अन्यथा, यूज़र को पर्सनलाइज़्ड “Hello” प्रतिक्रिया मिलेगी।
ध्यान रखें कि आप अपने UDF के लिए एक या अधिक फ़ंक्शन पैरामीटर्स भी परिभाषित कर सकते हैं। इसके बारे में आप “फ़ंक्शन आर्ग्युमेंट्स” सेक्शन में और सीखेंगे। इसके अलावा, आपका फ़ंक्शन एक या एक से अधिक वैल्यू लौटा सकता है या नहीं भी लौटा सकता है।
return स्टेटमेंट
ध्यान दें कि आप अपने UDF hello() में कुछ प्रिंट कर रहे हैं, इसलिए वास्तव में आपको उसे रिटर्न करने की ज़रूरत नहीं है। ऊपर दिए गए फ़ंक्शन और इस वाले में कोई अंतर नहीं होगा:
हालाँकि, यदि आप अपने फ़ंक्शन के परिणाम के साथ आगे काम करना चाहते हैं और उस पर कुछ ऑपरेशन्स आज़माना चाहते हैं, तो आपको वास्तव में कोई वैल्यू रिटर्न करने के लिए return स्टेटमेंट का उपयोग करना होगा, जैसे कि एक स्ट्रिंग, एक इंटीजर, …। यह परिदृश्य देखें, जहाँ hello() एक स्ट्रिंग "hello" लौटाता है, जबकि hello_noreturn() None लौटाता है:
दूसरा फ़ंक्शन आपको एरर देगा क्योंकि आप None के साथ कोई ऑपरेशन नहीं कर सकते। आपको एक TypeError मिलेगा, जो कहेगा कि आप NoneType (यानी hello_noreturn() के परिणाम None) और int (2) के लिए गुणा ऑपरेशन नहीं कर सकते।
टिप फ़ंक्शन्स जैसे ही return स्टेटमेंट पर पहुँचते हैं, वे तुरंत बाहर निकल जाते हैं, भले ही इसका मतलब यह हो कि वे कोई वैल्यू रिटर्न नहीं करेंगे:
एक और महत्वपूर्ण बात यह है कि आप return स्टेटमेंट का उपयोग एक से अधिक वैल्यू लौटाने के लिए भी कर सकते हैं। ऐसा करने के लिए, आप tuples का उपयोग करते हैं।
याद रखें कि यह डेटा स्ट्रक्चर सूची के समान होता है: इसमें कई वैल्यू हो सकती हैं। हालाँकि, tuples अम्यूटेबल होते हैं, यानी आप इसमें संग्रहीत मानों को बदल नहीं सकते! आप इसे डबल कोष्ठकों () की मदद से बनाते हैं। आप कॉमा और असाइनमेंट ऑपरेटर की मदद से tuples को कई वेरिएबल्स में अनपैक कर सकते हैं।
निम्न उदाहरण देखें कि आपका फ़ंक्शन कई वैल्यू कैसे रिटर्न कर सकता है:
नोट कि return स्टेटमेंट return sum, a का परिणाम return (sum, a) जैसा ही होगा: पहला विकल्प दरअसल sum और a को अंदरूनी तौर पर एक tuple में पैक कर देता है!
फ़ंक्शन को कैसे कॉल करें
पिछले सेक्शनों में, आपने फ़ंक्शन को कॉल करने के कई उदाहरण देखे हैं। फ़ंक्शन को कॉल करने का मतलब है कि आप उस फ़ंक्शन को निष्पादित करते हैं जिसे आपने परिभाषित किया है — या तो सीधे Python प्रॉम्प्ट से या किसी और फ़ंक्शन के माध्यम से (जैसा कि आप “Nested Functions” सेक्शन में देखेंगे)।
अपने नए परिभाषित फ़ंक्शन hello() को बस hello() चलाकर कॉल करें, ठीक नीचे दिए गए DataCamp Light चंक की तरह:
Python फ़ंक्शन में docstrings कैसे जोड़ें
Python में फ़ंक्शन्स लिखने का एक और आवश्यक पहलू: docstrings। Docstrings बताते हैं कि आपका फ़ंक्शन क्या करता है, जैसे वह कौन-सी गणनाएँ करता है या उसके रिटर्न वैल्यू क्या हैं। ये विवरण आपके फ़ंक्शन के लिए डाक्यूमेंटेशन का काम करते हैं ताकि कोई भी जो आपके फ़ंक्शन की docstring पढ़ता है, बिना फ़ंक्शन डेफ़िनिशन के सभी कोड को ट्रेस किए, समझ सके कि आपका फ़ंक्शन क्या करता है।
फ़ंक्शन docstrings फ़ंक्शन हेडर के तुरंत बाद की लाइन में रखे जाते हैं और ट्रिपल कोटेशन मार्क्स के बीच लिखे जाते हैं। आपके hello() फ़ंक्शन के लिए उपयुक्त Docstring है ‘Prints “Hello World”’.
def hello() -> None:
"""Prints "Hello World"."""
print("Hello World")
नोट कि docstrings यहाँ दिए गए उदाहरण से कहीं लंबी भी हो सकती हैं। अगर आप docstrings को और विस्तार से पढ़ना चाहते हैं, तो Python लाइब्रेरीज़ के कुछ Github रिपॉज़िटरी, जैसे scikit-learn या pandas, देखें, जहाँ आपको बहुत से उदाहरण मिलेंगे!
टाइप हिंट्स
Docstrings से काफ़ी संबंधित — और आधुनिक Python कोड में लगभग उतने ही आम — टाइप हिंट्स हैं। Python 3.5 से, आप अपने फ़ंक्शन के पैरामीटर्स और रिटर्न वैल्यू को अपेक्षित टाइप्स के साथ एनोटेट कर सकते हैं। यह सबसे सरल उदाहरण है:
def plus(a: int, b: int) -> int:
return a + b
प्रत्येक पैरामीटर के बाद : int का मतलब है "यह एक इंटीजर होना चाहिए," और कोष्ठकों के बाद -> int कहता है "यह फ़ंक्शन एक इंटीजर लौटाता है।" Python स्वयं रनटाइम पर इन एनोटेशन्स को लागू नहीं करता — आप फिर भी plus() को एक स्ट्रिंग पास कर सकते हैं और Python तब तक शिकायत नहीं करेगा जब तक कुछ टूट न जाए। लेकिन mypy, pyright, और VS Code व PyCharm जैसे एडिटर्स में बने टाइप चेकर जैसे टूल, आपके कोड को चलाने से पहले ही इन हिंट्स की मदद से बग पकड़ लेते हैं।
और जटिल टाइप्स के लिए, आप बिल्ट-इन जेनेरिक्स का सीधे उपयोग कर सकते हैं (Python 3.9+) या typing मॉड्यूल से इम्पोर्ट कर सकते हैं:
def greet(names: list[str]) -> None:
for name in names:
print(f"Hello {name}")
def find_user(user_id: int) -> dict | None:
# returns the user dict, or None if not found
...
Python में फ़ंक्शन आर्ग्युमेंट्स
पहले, आपने पैरामीटर्स और आर्ग्युमेंट्स के बीच के अंतर के बारे में सीखा। संक्षेप में, आर्ग्युमेंट्स वे चीज़ें हैं जो किसी फ़ंक्शन या मेथड कॉल को दी जाती हैं, जबकि फ़ंक्शन या मेथड का कोड उन आर्ग्युमेंट्स को उनके पैरामीटर नामों से संदर्भित करता है। Python UDFs चार प्रकार के आर्ग्युमेंट्स ले सकते हैं:
- डिफ़ॉल्ट आर्ग्युमेंट्स
- आवश्यक (required) आर्ग्युमेंट्स
- कीवर्ड आर्ग्युमेंट्स
- वैरिएबल संख्या के आर्ग्युमेंट्स
डिफ़ॉल्ट आर्ग्युमेंट्स
डिफ़ॉल्ट आर्ग्युमेंट्स वे होते हैं जो फ़ंक्शन कॉल के दौरान कोई वैल्यू पास न होने पर एक डिफ़ॉल्ट वैल्यू ले लेते हैं। आप यह डिफ़ॉल्ट वैल्यू असाइनमेंट ऑपरेटर = के साथ दे सकते हैं, जैसे निम्न उदाहरण में:
आवश्यक आर्ग्युमेंट्स
नाम से ही स्पष्ट है, UDF के आवश्यक आर्ग्युमेंट्स वे होते हैं जिन्हें होना ही चाहिए। इन आर्ग्युमेंट्स को फ़ंक्शन कॉल के समय पास करना पड़ता है और ठीक उसी क्रम में, जैसे इस उदाहरण में:
फ़ंक्शन को बिना एरर के कॉल करने के लिए आपको a और b पैरामीटर्स से मैप होने वाले आर्ग्युमेंट्स चाहिए। अगर आप a और b को अदल-बदल दें, तो परिणाम अलग नहीं होगा, लेकिन यह तब बदल सकता है जब आप plus() को निम्न रूप में बदल दें:
कीवर्ड आर्ग्युमेंट्स
यदि आप यह सुनिश्चित करना चाहते हैं कि आप सभी पैरामीटर्स को सही क्रम में कॉल कर रहे हैं, तो आप अपने फ़ंक्शन कॉल में कीवर्ड आर्ग्युमेंट्स का उपयोग कर सकते हैं। आप इन्हें उनके पैरामीटर नाम से आर्ग्युमेंट्स की पहचान करने के लिए उपयोग करते हैं। इसे थोड़ा और स्पष्ट करने के लिए ऊपर वाले उदाहरण को लें:
ध्यान दें कि कीवर्ड आर्ग्युमेंट्स का उपयोग करके, आप पैरामीटर्स के क्रम को बदल भी सकते हैं और फिर भी फ़ंक्शन चलाने पर वही परिणाम पाएँगे:
वैरिएबल संख्या के आर्ग्युमेंट्स
ऐसे मामलों में जहाँ आपको यह नहीं पता कि आप फ़ंक्शन को कितने आर्ग्युमेंट्स पास करना चाहते हैं, आप *args के साथ निम्न सिंटैक्स का उपयोग कर सकते हैं:
एस्टेरिस्क (*) उस वैरिएबल नाम के पहले लगाया जाता है जो सभी nonkeyword वैरिएबल आर्ग्युमेंट्स के मानों को रखता है। ध्यान दें कि आप *varint, *var_int_args या कोई और नाम भी plus() फ़ंक्शन को पास कर सकते थे।
टिप: *args को किसी दूसरे नाम से बदलकर देखें जिसमें एस्टेरिस्क शामिल हो। आप देखेंगे कि ऊपर का कोड वैसे ही काम करता रहेगा!
आप देखते हैं कि ऊपर दिया गया फ़ंक्शन बिल्ट-इन Python sum() फ़ंक्शन का उपयोग करके उन सभी आर्ग्युमेंट्स का योग निकालता है जो plus() को पास किए जाते हैं।
ग्लोबल बनाम लोकल वेरिएबल्स
आम तौर पर, जो वेरिएबल किसी फ़ंक्शन बॉडी के अंदर परिभाषित होते हैं, उनका स्कोप लोकल होता है, और जो बाहर परिभाषित होते हैं, उनका स्कोप ग्लोबल होता है। यानी, लोकल वेरिएबल्स किसी फ़ंक्शन ब्लॉक के भीतर परिभाषित होते हैं और सिर्फ़ उसी फ़ंक्शन के अंदर एक्सेस किए जा सकते हैं, जबकि ग्लोबल वेरिएबल्स को आपकी स्क्रिप्ट में मौजूद सभी फ़ंक्शन्स एक्सेस कर सकते हैं:
आप देखेंगे कि जब आप फ़ंक्शन बॉडी के अंदर परिभाषित लोकल वेरिएबल total को प्रिंट करने की कोशिश करते हैं, तो आपको NameError मिलेगा, जो कहेगा कि name 'total' is not defined। दूसरी ओर, init वेरिएबल बिना किसी समस्या के प्रिंट किया जा सकता है।
Positional-only और keyword-only पैरामीटर्स
Python 3.8 से, आप अपनी फ़ंक्शन सिग्नेचर में दो विशेष मार्कर्स: / और * का उपयोग करके यह नियंत्रित कर सकते हैं कि आर्ग्युमेंट्स कैसे पास किए जाएँ। / से पहले की हर चीज़ केवल पॉज़िशनली पास की जा सकती है; * के बाद की हर चीज़ केवल कीवर्ड के जरिए पास की जा सकती है।
def greet(name, /, greeting="Hello", *, punctuation="!"):
print(f"{greeting} {name}{punctuation}")
कॉल साइट पर यह इस तरह दिखता है:
greet("Alice") # works
greet("Alice", greeting="Hi") # works
greet("Alice", "Hi", punctuation="?") # works
greet(name="Alice") # TypeError: name is positional-only
greet("Alice", "Hi", "?") # TypeError: punctuation is keyword-only
आप ऐसा क्यों चाहेंगे? दो मुख्य कारण।
पहला, positional-only पैरामीटर्स आपको बाद में उनके नाम बदलने की आज़ादी देते हैं बिना किसी के कोड को तोड़े — क्योंकि कोई भी पैरामीटर नाम को कीवर्ड के रूप में इस्तेमाल नहीं कर सकता, आप इसे बदलने के लिए स्वतंत्र हैं।
दूसरा, keyword-only पैरामीटर्स कॉलर्स को यह स्पष्ट करने के लिए बाध्य करते हैं कि वे क्या पास कर रहे हैं, जो तब कॉल्स को अधिक पठनीय बनाता है जब आपके पास कई वैकल्पिक फ़्लैग्स या सेटिंग्स हों।
संक्षेप में, ये आशय (intent) को साफ़-साफ़ लागू करने का एक सुथरा तरीका हैं।
Python में गुमनाम (Anonymous) फ़ंक्शन्स
गुमनाम फ़ंक्शन्स को Python में lambda फ़ंक्शन्स भी कहा जाता है क्योंकि इन्हें मानक def कीवर्ड के बजाय lambda कीवर्ड से घोषित किया जाता है।
ऊपर दिए गए DataCamp Light चंक में, lambda x: x*2 गुमनाम या lambda फ़ंक्शन है। x आर्ग्युमेंट है, और x*2 वह एक्सप्रेशन या निर्देश है जिसका मूल्यांकन कर रिटर्न किया जाता है। इस फ़ंक्शन की ख़ास बात यह है कि इसका कोई नाम नहीं है, जैसे कि आपने इस ट्यूटोरियल के पहले भाग में देखे उदाहरणों में था। यदि आपको ऊपर वाले फ़ंक्शन को UDF में लिखना हो, तो परिणाम निम्न होगा:
def double(x):
return x*2
आइए दो आर्ग्युमेंट्स वाले एक और lambda फ़ंक्शन का उदाहरण देखें:
आप गुमनाम फ़ंक्शन्स का उपयोग तब करते हैं जब आपको थोड़े समय के लिए बिना नाम का फ़ंक्शन चाहिए, और जिसे रनटाइम पर बनाया जाता है। ऐसे विशिष्ट संदर्भ जहाँ यह प्रासंगिक होता है, वे हैं जब आप filter(), map() और reduce() के साथ काम कर रहे हों:
filter() फ़ंक्शन, जैसा कि नाम से स्पष्ट है, मूल इनपुट सूची my_list को किसी मानदंड >10 के आधार पर फ़िल्टर करता है। दूसरी ओर, map() के साथ, आप सूची my_list के सभी आइटम्स पर कोई फ़ंक्शन लागू करते हैं। इस मामले में, आप सभी तत्वों को 2 से गुणा करते हैं।
ध्यान दें कि reduce() फ़ंक्शन functools लाइब्रेरी का हिस्सा है। आप इस फ़ंक्शन का उपयोग my_list की आइटम्स पर बाएँ से दाएँ क्रम में क्रमिक रूप से करते हैं और अनुक्रम को एक एकल मान में घटाते हैं, जो इस मामले में 55 है।
Python में main() को फ़ंक्शन की तरह उपयोग करना
यदि आपको Java जैसी अन्य प्रोग्रामिंग भाषाओं का अनुभव है, तो आप जानते होंगे कि फ़ंक्शन्स को निष्पादित करने के लिए main फ़ंक्शन आवश्यक होता है। जैसा कि आपने ऊपर दिए उदाहरणों में देखा, Python के लिए यह ज़रूरी नहीं है। फिर भी, अपने Python प्रोग्राम में main() फ़ंक्शन शामिल करना आपके कोड को तार्किक रूप से व्यवस्थित करने में सहायक हो सकता है — सबसे महत्वपूर्ण घटक इसी main() फ़ंक्शन के भीतर समाहित होते हैं।
आप आसानी से एक main() फ़ंक्शन परिभाषित कर सकते हैं और इसे वैसा ही कॉल कर सकते हैं जैसा आपने ऊपर अन्य सभी फ़ंक्शन्स के साथ किया है:
हालाँकि, अभी की स्थिति में, जब आप इसे किसी मॉड्यूल के रूप में इम्पोर्ट करेंगे, तो आपके main() फ़ंक्शन का कोड कॉल हो जाएगा। यह सुनिश्चित करने के लिए कि ऐसा न हो, आप __name__ == '__main__' होने पर ही main() फ़ंक्शन को कॉल करते हैं।
इसका मतलब है कि ऊपर दिए गए कोड चंक का कोड इस प्रकार बन जाता है:
नोट कि __main__ फ़ंक्शन के अलावा, आपके पास एक __init__ फ़ंक्शन भी होता है जो किसी क्लास या ऑब्जेक्ट के इंस्टेंस को इनिशियलाइज़ करता है। सरल शब्दों में, यह कंस्ट्रक्टर या इनिशियलाइज़र की तरह काम करता है और जब आप किसी क्लास का नया इंस्टेंस बनाते हैं तो अपने-आप कॉल होता है। इस फ़ंक्शन के साथ, नया बना ऑब्जेक्ट पैरामीटर self को असाइन होता है, जिसे आपने इस ट्यूटोरियल में पहले देखा था। निम्न उदाहरण देखें:
class Dog:
"""A simple Dog class.
Args:
legs: Number of legs so that the dog can walk.
color: The color of the fur.
"""
def __init__(self, legs: int, color: str) -> None:
self.legs = legs
self.color = color
def bark(self) -> str:
return "bark" * 2
if __name__ == "__main__":
dog = Dog(4, "brown")
print(dog.bark())
Python फ़ंक्शन्स का अभ्यास जारी रखें
बधाई हो! आपने Python में फ़ंक्शन्स पर यह छोटा ट्यूटोरियल पूरा कर लिया है। अगर आप अन्य बुनियादी Python प्रोग्रामिंग सामग्री को दोहराना चाहते हैं, तो Data Types for Data Science मिस न करें, यह एक ऐसा कोर्स है जहाँ आप लिस्ट्स, डिक्शनरीज़, ट्यूपल्स, सेट्स, और डेट टाइम्स का अपना ज्ञान समेकित करेंगे और अभ्यास करेंगे।
Python फ़ंक्शन्स से जुड़े अक्सर पूछे जाने वाले प्रश्न
Python में फ़ंक्शन क्या है?
फ़ंक्शन कोड का एक पुन: उपयोग योग्य ब्लॉक है जो किसी विशिष्ट कार्य को करता है। यह इनपुट ले सकता है, उन्हें प्रोसेस कर सकता है, और आउटपुट लौटा सकता है।
आप Python में फ़ंक्शन कैसे परिभाषित करते हैं?
Python में फ़ंक्शन परिभाषित करने के लिए def कीवर्ड का उपयोग करें, फ़ंक्शन का नाम दें, वैकल्पिक पैरामीटर्स को कोष्ठकों में जोड़ें, अपना कोड लिखें, और वैकल्पिक रूप से कोई वैल्यू return करें।
Python में फ़ंक्शन्स और मेथड्स में क्या अंतर है?
फ़ंक्शन्स स्वतंत्र होते हैं, जबकि मेथड्स क्लासेज़ से संबंधित होते हैं। सभी मेथड्स फ़ंक्शन्स हैं, लेकिन सभी फ़ंक्शन्स मेथड्स नहीं होते।
Python में फ़ंक्शन्स के प्रकार क्या हैं?
Python में बिल्ट-इन फ़ंक्शन्स (जैसे print()), यूज़र-डिफ़ाइन्ड फ़ंक्शन्स (आपकी कस्टम रचनाएँ), और गुमनाम फ़ंक्शन्स (कम समय के लिए बनने वाले lambda फ़ंक्शन्स) होते हैं।
पैरामीटर्स और आर्ग्युमेंट्स में क्या अंतर है?
पैरामीटर्स आपके फ़ंक्शन डेफ़िनिशन में placeholders होते हैं, और आर्ग्युमेंट्स वे वास्तविक मान होते हैं जिन्हें आप फ़ंक्शन को कॉल करते समय पास करते हैं।
lambda फ़ंक्शन क्या है?
lambda फ़ंक्शन एक एक-पंक्ति का, बिना नाम का फ़ंक्शन होता है जो त्वरित कार्यों के लिए उपयोगी है।
__main__ फ़ंक्शन का उपयोग क्यों करें?
__main__ फ़ंक्शन आपके कोड को व्यवस्थित रखता है और सुनिश्चित करता है कि विशेष हिस्से तभी चलें जब स्क्रिप्ट सीधे चलाई जाए, न कि इम्पोर्ट करने पर।
ग्लोबल और लोकल वेरिएबल्स में क्या अंतर है?
ग्लोबल वेरिएबल्स हर जगह काम करते हैं, जबकि लोकल वेरिएबल्स केवल अपने फ़ंक्शन के अंदर ही रहते हैं।