目次
1. ग्लोबल भेरिएबल के हो?
ग्लोबल भेरिएबलको मूल अवधारणा
Python मा ग्लोबल भेरिएबल भनेको सम्पूर्ण प्रोग्रामभर पहुँचयोग्य भेरिएबल हो। यसलाई फङ्सन वा क्लासको बाहिर परिभाषित गरिन्छ, र विभिन्न फङ्सनहरू वा मोड्युलहरू बीच डेटा साझेदारी गर्न प्रयोग गरिन्छ। तर, ग्लोबल भेरिएबलको दुरुपयोगले अनपेक्षित बगको कारण बन्न सक्छ, त्यसैले प्रयोग गर्दा सावधानी आवश्यक छ।# ग्लोबल भेरिएबलको उदाहरण
global_var = "ग्लोबल भेरिएबल"
def show_global():
print(global_var)
show_global() # आउटपुट: ग्लोबल भेरिएबल
ग्लोबल भेरिएबलहरू फङ्सन वा क्लासको बाहिर परिभाषित गरिन्छ, र प्रोग्रामको कुनै पनि स्थानबाट सन्दर्भ गर्न सकिन्छ। तर, परिवर्तन गर्दा विशेष सावधानी आवश्यक हुन्छ।लोकल भेरिएबलसँगको भिन्नता
ग्लोबल भेरिएबलभन्दा फरक, लोकल भेरिएबलहरू फङ्सनभित्र परिभाषित गरिन्छ, र तिनीहरूको स्कोप त्यो फङ्सनभित्र मात्र सीमित हुन्छ। फङ्सन समाप्त भएपछि लोकल भेरिएबलहरू नष्ट हुन्छन्, र अन्य फङ्सनहरू वा बाहिरबाट पहुँच गर्न सकिँदैन।def example_func():
local_var = "लोकल भेरिएबल"
print(local_var)
example_func() # आउटपुट: लोकल भेरिएबल
# print(local_var) # त्रुटि: लोकल भेरिएबल फङ्सनको बाहिरबाट पहुँच गर्न सकिँदैन
लोकल भेरिएबल र ग्लोबल भेरिएबलको भिन्नता बुझेर, उपयुक्त रूपमा प्रयोग गर्दा कोडको मर्मतयोग्यता सुधारिन्छ।2. कार्यभित्र ग्लोबल भेरिएबलको प्रयोग विधि
ग्लोबल भेरिएबलको सन्दर्भ र परिवर्तन
ग्लोबल भेरिएबल कार्यभित्र पनि सन्दर्भ गर्न सकिन्छ, तर कार्यभित्र यसको मान परिवर्तन गर्नglobal
कुञ्जीशब्द आवश्यक हुन्छ। यदि यो प्रयोग नगरेमा, कार्यभित्र उही नामको लोकल भेरिएबल सिर्जना हुन्छ, जसले ग्लोबल भेरिएबललाई असर गर्दैन।counter = 0 # ग्लोबल भेरिएबल
def increase_counter():
global counter
counter += 1
increase_counter()
print(counter) # आउटपुट: 1
nonlocal
कुञ्जीशब्दको परिचय
nonlocal
कुञ्जीशब्द नेस्टेड फङ्सनहरूमा बाहिरी लोकल भेरिएबल परिवर्तन गर्न प्रयोग गरिन्छ। क्लोजर प्रयोग गर्दा वा फङ्सनभित्र स्थिती राख्ने केसहरूमा यो उपयोगी हुन्छ।def outer_func():
outer_var = "बाहिरी"
def inner_func():
nonlocal outer_var
outer_var = "परिवर्तित बाहिरी"
inner_func()
print(outer_var)
outer_func() # आउटपुट: परिवर्तित बाहिरी
nonlocal
प्रयोग गरेर, भित्री फङ्सनबाट बाहिरी लोकल भेरिएबलमा पहुँच गरी, त्यसलाई सञ्चालन गर्न सकिन्छ।3. ग्लोबल भेरिएबल प्रयोग गर्दा ध्यान दिनुपर्ने बुँदाहरू
ग्लोबल भेरिएबलको दुरुपयोगबाट हुने जोखिम
ग्लोबल भेरिएबलहरू अत्यन्त उपयोगी छन्, तर दुरुपयोग गर्दा सम्पूर्ण प्रोग्राममा अनपेक्षित प्रभाव पर्न सक्छ। विशेष गरी, धेरै फङ्सनहरूले एउटै ग्लोबल भेरिएबल परिवर्तन गर्दा, कुन फङ्सनले कहिले र कसरी मान परिवर्तन गर्यो भन्ने ट्र्याक गर्न कठिन हुन्छ।counter = 0
def increment():
global counter
counter += 1
def decrement():
global counter
counter -= 1
increment()
decrement()
print(counter) # आउटपुट: 0
यसरी, ग्लोबल भेरिएबलहरू विभिन्न स्थानहरूमा परिवर्तन गरिएमा बगहरू उत्पन्न हुन सजिलो हुन्छ, त्यसैले सकेसम्म प्रयोगलाई सीमित गर्नु, र अन्य तरिकाले डेटा व्यवस्थापन गर्नु सिफारिस गरिन्छ।त्रुटि ह्यान्डलिङ र डिबगिङ
ग्लोबल भेरिएबल प्रयोग गर्दा अनपेक्षित त्रुटिहरू उत्पन्न हुन सक्छ। त्रुटि ह्यान्डलिङ थपेर,logging
मोड्युल प्रयोग गरेर, त्रुटि कहाँ भयो भनेर पहिचान गर्न र डिबगिङ सजिलो बनाइन्छ।import logging
logging.basicConfig(level=logging.DEBUG)
counter = 0
def increment():
global counter
try:
counter += 1
logging.debug(f"counter incremented: {counter}")
except Exception as e:
logging.error(f"त्रुटि: {e}")
increment()
यो विधि प्रयोग गरेर, ग्लोबल भेरिएबलको परिवर्तन कहाँ भयो र कस्तो त्रुटि उत्पन्न भयो भन्ने रेकर्ड गर्न सकिन्छ।4. ग्लोबल भेरिएबलहरूको सर्वोत्तम अभ्यास
ग्लोबल भेरिएबलहरूको प्रयोगलाई न्यूनतम राख्नु
ग्लोबल भेरिएबलहरूलाई सम्भव भएसम्म प्रयोगलाई न्यूनतम राख्न सिफारिस गरिन्छ। यसको सट्टा, फङ्सनका आर्गुमेन्टहरू र रिटर्न भ्यालुहरू प्रयोग गरेर डेटा साटासाट गर्दा, डेटा प्रवाह स्पष्ट हुन्छ र अनिच्छित परिवर्तनहरूबाट बच्न सकिन्छ।def add_points(score, points):
return score + points
current_score = 0
current_score = add_points(current_score, 10)
print(current_score) # आउटपुट: 10
यसरी, फङ्सन आर्गुमेन्ट र रिटर्न भ्यालुहरूलाई उपयोग गरेर, ग्लोबल भेरिएबलहरूमा निर्भर नगरी डेटा व्यवस्थापन गर्न सकिन्छ।क्लास प्रयोग गरेर अवस्था व्यवस्थापन
क्लास प्रयोग गरेर, ग्लोबल भेरिएबलहरू बिना अवस्था व्यवस्थापन गर्न सकिन्छ। क्लास डेटा क्याप्सुलेशन र स्कोपलाई स्पष्ट बनाउनको लागि प्रभावकारी उपाय हो।class Game:
def __init__(self):
self.score = 0
def add_points(self, points):
self.score += points
game = Game()
game.add_points(10)
print(game.score) # आउटपुट: 10
क्लास प्रयोग गरेर, अवस्थालाई व्यक्तिगत इन्स्ट्यान्समा बन्द गरेर, अन्य भागबाट अनपेक्षित परिवर्तनहरूलाई रोक्न सकिन्छ।5. व्यावहारिक उदाहरणहरू र अनुप्रयोगहरू
गेम विकासमा प्रयोगको उदाहरण
गेम विकासमा, स्कोर र जीवनको स्थितिलाई व्यवस्थापन गर्न ग्लोबल भेरिएबलहरू प्रयोग गरिन सक्छ, तर ठूला परियोजनाहरूमा वर्गहरू वा डाटाबेस प्रयोग गरेर व्यवस्थापन सिफारिस गरिन्छ।score = 0 # ग्लोबल भेरिएबल
def increase_score(points):
global score
score += points
increase_score(10)
print(f"खेलाडी स्कोर: {score}") # आउटपुट: खेलाडी स्कोर: 10
कन्फिगरेसन व्यवस्थापनको लागि ग्लोबल भेरिएबलहरू
एप्लिकेशनभर प्रयोग हुने कन्फिगरेसन जानकारी (उदाहरण: डिबग मोड र संस्करण) प्रायः ग्लोबल भेरिएबलको रूपमा ह्यान्डल गरिन्छ, तर कन्फिगरेसन फाइल वा वातावरणीय भेरिएबलसँग जोडेर यसलाई प्रभावकारी रूपमा व्यवस्थापन गर्न सकिन्छ।config = {
'debug': True,
'version': '1.0'
}
def print_config():
print(f"डिबग मोड: {config['debug']}, संस्करण: {config['version']}")
print_config() # आउटपुट: डिबग मोड: True, संस्करण: 1.0

6. सारांश र अर्को चरण
ग्लोबल भेरिएबलहरू सरल परिदृश्यहरूमा उपयोगी हुन्छन्, तर दुरुपयोग गर्दा कोड जटिल हुन्छ र बगको कारण बन्छ। फङ्सन आर्गुमेन्ट, रिटर्न भ्यालु, क्लासको प्रयोग गरेर ग्लोबल भेरिएबलको प्रयोगलाई न्यूनतम राख्नु, प्रभावकारी र सुरक्षित प्रोग्राम डिजाइनतिर लैजान्छ।अगाडि सिक्नुपर्ने विषयहरू
अगिलो चरणको रूपमा, क्लोजर, मड्युल स्कोप, अब्जेक्ट‑ओरिएन्टेड प्रोग्रामिङ (OOP) बारे सिक्न सिफारिस गरिन्छ। यसले ग्लोबल भेरिएबलमा निर्भर नगरी, अझ जटिल प्रोग्रामहरू डिजाइन गर्न सकिन्छ।बाह्य स्रोतहरू र सन्दर्भ लिङ्कहरू
- Python आधिकारिक दस्तावेज Python को स्कोप, क्लोजर, OOP सम्बन्धी विस्तृत व्याख्या प्रदान गर्दछ। विशेष गरी, LEGB नियम (लोकल, एन्क्लोजिंग, ग्लोबल, बिल्ट‑इन) को समझमा सहयोगी हुन्छ। Python आधिकारिक दस्तावेज