पायथन - हैश टेबल

हैश टेबल एक प्रकार की डेटा संरचना है जिसमें डेटा तत्व का पता या इंडेक्स मान हैश फ़ंक्शन से उत्पन्न होता है। यह डेटा को तेजी से एक्सेस करता है क्योंकि इंडेक्स वैल्यू डेटा वैल्यू के लिए एक कुंजी के रूप में व्यवहार करता है। दूसरे शब्दों में, हैश टेबल की-वैल्यू जोड़े को स्टोर करता है लेकिन कुंजी हैशिंग फ़ंक्शन के माध्यम से उत्पन्न होती है।

तो डेटा तत्व की खोज और प्रविष्टि फ़ंक्शन बहुत तेज़ हो जाता है क्योंकि कुंजी मान स्वयं उस सरणी का सूचकांक बन जाता है जो डेटा संग्रहीत करता है।

पायथन में, शब्दकोश डेटा प्रकार हैश तालिकाओं के कार्यान्वयन का प्रतिनिधित्व करते हैं। शब्दकोश में कुंजी निम्नलिखित आवश्यकताओं को पूरा करती है।

  • डिक्शनरी की चाबियां हैशेबल हैं, हैश फ़ंक्शन द्वारा बनाई गई हैं जो हैश फ़ंक्शन को दिए गए प्रत्येक अद्वितीय मान के लिए अद्वितीय परिणाम उत्पन्न करती हैं।
  • किसी शब्दकोश में डेटा तत्वों का क्रम निश्चित नहीं है।

तो हम नीचे दिए गए डेटा प्रकारों का उपयोग करके हैश तालिका के कार्यान्वयन को देखते हैं।

शब्दकोश में पहुँच मान

शब्दकोश तत्वों तक पहुंचने के लिए, आप इसके मूल्य को प्राप्त करने के लिए कुंजी के साथ परिचित वर्ग कोष्ठक का उपयोग कर सकते हैं।

# Declare a dictionary 
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}

# Accessing the dictionary with its key
print "dict['Name']: ", dict['Name']
print "dict['Age']: ", dict['Age']

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

dict['Name']:  Zara
dict['Age']:  7

शब्दकोश अद्यतन

आप एक नई प्रविष्टि या एक कुंजी-मूल्य जोड़ी जोड़कर एक शब्दकोश अपडेट कर सकते हैं, एक मौजूदा प्रविष्टि को संशोधित कर सकते हैं, या एक मौजूदा प्रविष्टि को हटा सकते हैं जैसा कि सरल उदाहरण में नीचे दिखाया गया है -

# Declare a dictionary
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
dict['Age'] = 8; # update existing entry
dict['School'] = "DPS School"; # Add new entry
print "dict['Age']: ", dict['Age']
print "dict['School']: ", dict['School']

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

When the above code is executed, it produces the following result −
dict['Age']:  8
dict['School']:  DPS School

शब्दकोश तत्वों को हटाएँ

आप या तो व्यक्तिगत शब्दकोश तत्वों को हटा सकते हैं या किसी शब्दकोश की संपूर्ण सामग्री को साफ़ कर सकते हैं। आप एकल ऑपरेशन में पूरे शब्दकोश को हटा भी सकते हैं। स्पष्ट रूप से एक पूरे शब्दकोश को हटाने के लिए, बस डेल स्टेटमेंट का उपयोग करें। -

dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
del dict['Name']; # remove entry with key 'Name'
dict.clear();     # remove all entries in dict
del dict ;        # delete entire dictionary

print "dict['Age']: ", dict['Age']
print "dict['School']: ", dict['School']

यह निम्न परिणाम उत्पन्न करता है। ध्यान दें कि एक अपवाद उठाया जाता है क्योंकि डेल के बाद डिक्शनरी डिक्शनरी मौजूद नहीं है -

dict['Age']:
Traceback (most recent call last):
   File "test.py", line 8, in 
      
        print "dict['Age']: ", dict['Age']; TypeError: 'type' object is unsubscriptable