Python — Maps
Python Maps also called ChainMap is a type of data structure to manage multiple dictionaries together as one unit. The combined dictionary contains the key and value pairs in a specific sequence eliminating any duplicate keys. The best use of ChainMap is to search through multiple dictionaries at a time and get the proper key-value pair mapping. We also see that these ChainMaps behave as stack data structure.
Creating a ChainMap
We create two dictionaries and club them using the ChainMap method from the collections library. Then we print the keys and values of the result of the combination of the dictionaries. If there are duplicate keys, then only the value from the first key is preserved.
Example
import collections dict1 = dict2 = res = collections.ChainMap(dict1, dict2) # Creating a single dictionary print(res.maps,'\n') print('Keys = <>'.format(list(res.keys()))) print('Values = <>'.format(list(res.values()))) print() # Print all the elements from the result print('elements:') for key, val in res.items(): print('<> = <>'.format(key, val)) print() # Find a specific value in the result print('day3 in res: <>'.format(('day1' in res))) print('day4 in res: <>'.format(('day4' in res)))
Output
When the above code is executed, it produces the following result −
[, ] Keys = ['day1', 'day3', 'day2'] Values = ['Mon', 'Wed', 'Tue'] elements: day1 = Mon day3 = Wed day2 = Tue day3 in res: True day4 in res: False
Map Reordering
If we change the order the dictionaries while clubbing them in the above example we see that the position of the elements get interchanged as if they are in a continuous chain. This again shows the behavior of Maps as stacks.
Example
import collections dict1 = dict2 = res1 = collections.ChainMap(dict1, dict2) print(res1.maps,'\n') res2 = collections.ChainMap(dict2, dict1) print(res2.maps,'\n')
Output
When the above code is executed, it produces the following result −
Updating Map
When the element of the dictionary is updated, the result is instantly updated in the result of the ChainMap. In the below example we see that the new updated value reflects in the result without explicitly applying the ChainMap method again.
Example
import collections dict1 = dict2 = res = collections.ChainMap(dict1, dict2) print(res.maps,'\n') dict2['day4'] = 'Fri' print(res.maps,'\n')
Output
When the above code is executed, it produces the following result −
Python hashmap tutorial | From Beginner to Advance in 2023
Before understanding the python hashmap it is important to understand the hashtable and hashmap functions in general.
In Python, the hash() function is used to generate a hash value for an object. The returns hash value is an integer, which is unique for each unique object. The hash() function can be used with built-in types such as numbers, strings and tuples, as well as with user-defined classes.
The hash() function is used internally in Python’s dictionary implementation. When you create a dictionary and add key-value pairs to it, Python automatically generates a hash value for each key and uses it to determine where to store the value in the hash table.
The user needs to keep in mind that if the object is mutable, the hash will change after modification. Thus, a hash map cannot be used with mutable keys or items.
Besides, it’s important to note that for user-defined classes, python by default uses the id of the object as a hash but if we want to define our own hash function for the objects of a class, we can define __hash__() function in class.
Python hashtable
A hash table is the underlying data structure used to implement a hashmap. A hash table uses a hash function to map keys to indices in an array, called buckets. The primary function of a hash function is to convert a given key into a specific index in an array, where the corresponding value associated with that key can be located or stored.
The hash function typically takes a key, performs some operations on it, and returns an integer value, known as the hash code or index. This hash code can be used as an index in the array.
In Python, a hash table is used to implement the dictionary class. When a user creates a dictionary and adds key-value pairs to it, Python automatically uses a hash table to store the key-value pairs in a way that allows for efficient searching, adding and removing elements by a key.
Introduction to python hashmap
Now we have a pretty good understanding of python hashtable and hash function, let’s proceed further and understand python hashmap.
In Python, a hashmap is implemented as a dictionary. The keys in a dictionary are hashed, which means that they are transformed into a fixed-size integer value, called a hash code. The hashmap uses this hashcode to store value on the specific index of the hash table and uses a key to search for the value on that specific index. When you look up a value in a dictionary by its key, the key is first passed through a hash function.
A dictionary is a data structure that stores key-value pairs, where each key is unique. Dictionaries are very efficient for searching, adding and deleting elements by key because the average time complexity of these operations is constant. However, the time complexity can be O(n) in the worst case when two keys have the same hashcode known as a collision.
Below is an example to create a dictionary and access its elements.
my_dict= my_dict['Name'] my_dict['Gender']
The dictionary my_dict contains Name, Age, Country, and Gender as the keys. We can get the values by specifying the keys in the dictionary.
Hashmap in python example
The hashmap or dictionary can be created to store the key-value pair. Below is an example of the same.
# Initialize an empty dictionary my_dict = <> # Add key-value pairs to the dictionary my_dict["first_name"] = "Jack" my_dict["country"] = "USA" my_dict["age"] = 45
we have initiated an empty directory and added key-value pair to it. Now the values from the my_dict can be retrieved as:
# Access values using their keys print(my_dict["first_name"]) print(my_dict["country"]) print(my_dict["age"])
The above codes print the respective values of keys.
Now all the keys from the my_dict can be retrieved using the below code
for key in my_dict: print(key) # Output: # "first_name" # "last_name" # "age"
similarly, we can also check if a key exists in the directory using the below code:
if "country" in my_dict: print("key present in my_dict") else: print("key is not present in my_dict")
Python hashmap vs dictionary
In Python, “hashmap” and “dictionary” refer to the same data structure. The dictionary data type is implemented as a hash table, which allows for fast access to values using keys. Dictionaries are used to store key-value pairs, where each key must be unique and immutable.
It’s worth noting that while in Python, the terms “hashmap” and “dictionary” refer to the same built-in data structure, in other programming languages the two terms may not be interchangeable.
In other programming languages, “hashmap” generally refers to a specific implementation of a map data structure, while “dictionary” refers to a different data structure.
Conclusion
I hope you have liked this tutorial on the python hashmap. In this blog, we have learned about the python hashmap and hashtables. We also understood python hashmap with various examples.
Please do let me know if you need further input.