Python-해시 테이블

해시 테이블은 데이터 요소의 주소 또는 인덱스 값이 해시 함수에서 생성되는 데이터 구조 유형입니다. 그러면 인덱스 값이 데이터 값의 키로 작동하므로 데이터에 더 빠르게 액세스 할 수 있습니다. 즉, 해시 테이블은 키-값 쌍을 저장하지만 키는 해싱 함수를 통해 생성됩니다.

따라서 키 값 자체가 데이터를 저장하는 배열의 인덱스가되므로 데이터 요소의 검색 및 삽입 기능이 훨씬 빨라집니다.

Python에서 Dictionary 데이터 유형은 해시 테이블의 구현을 나타냅니다. 사전의 키는 다음 요구 사항을 충족합니다.

  • 사전의 키는 해시 가능합니다. 즉, 해시 함수에 제공된 각 고유 값에 대해 고유 한 결과를 생성하는 해싱 함수에 의해 생성됩니다.
  • 사전에있는 데이터 요소의 순서는 고정되지 않습니다.

따라서 아래와 같은 사전 데이터 유형을 사용하여 해시 테이블의 구현을 확인합니다.

사전의 값에 액세스

사전 요소에 액세스하려면 키와 함께 익숙한 대괄호를 사용하여 값을 얻을 수 있습니다.

# 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

사전 요소 삭제

개별 사전 요소를 제거하거나 사전의 전체 내용을 지울 수 있습니다. 한 번의 작업으로 전체 사전을 삭제할 수도 있습니다. 전체 사전을 명시 적으로 제거하려면 del 문을 사용하십시오. −

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']

다음과 같은 결과가 생성됩니다. del dict 사전이 더 이상 존재하지 않기 때문에 예외가 발생합니다.

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