Open In App

Python – Value Dictionary from Record List

Last Updated : 26 Apr, 2023
Improve
Improve
Like Article
Like
Save
Share
Report

Sometimes, while working with Python Records lists, we can have problems in which, we need to reform the dictionary taking just values of the binary dictionary. This can have applications in many domains which work with data. Let us discuss certain ways in which this task can be performed. 

Method #1 : Using loop + values() + update()

The combination of the above functions can be used to perform this task. In this the values are extracted using values() and updating the new dictionary is done using update(). 

Python3




# Python3 code to demonstrate working of
# Value Dictionary from Record List
# Using loop + values() + update()
 
# initializing list
test_list = [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
 
# printing original list
print("The original list is : " + str(test_list))
 
# Value Dictionary from Record List
# Using loop + values() + update()
res = dict()
for sub in test_list:
    res.update((sub.values(), ))
 
# printing result
print("The values dictionary is : " + str(dict(res)))


Output : 

The original list is : [{1: ‘gfg’, 2: ‘best’}, {3: ‘for’, 4: ‘geeks’}] The values dictionary is : {‘gfg’: ‘best’, ‘for’: ‘geeks’}

Time Complexity: O(n) where n is the total number of values in the list “test_list”. 
Auxiliary Space: O(n) where n is the total number of values in the list “test_list”. 

Method #2 : Using zip() + iter() 

The combination of the above functions can also be used to perform this task. In this, we perform to convert the list to iterator and pairing of values is done using zip(). 

Python3




# Python3 code to demonstrate working of
# Value Dictionary from Record List
# Using zip() + iter()
 
# initializing list
test_list = [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
 
# printing original list
print("The original list is : " + str(test_list))
 
# Value Dictionary from Record List
# Using zip() + iter()
res = dict()
 
for sub in test_list:
   
    itr = iter(sub.values())
    res.update(dict(zip(itr, itr)))
 
# printing result
print("The values dictionary is : " + str(res))


Output : 

The original list is : [{1: ‘gfg’, 2: ‘best’}, {3: ‘for’, 4: ‘geeks’}] The values dictionary is : {‘gfg’: ‘best’, ‘for’: ‘geeks’}

Time Complexity: O(n) where n is the number of elements in the dictionary. The zip() + iter() is used to perform the task and it takes O(n) time.
Auxiliary Space: O(n) additional space of size n is created where n is the number of elements in the dictionary.

Method #3:Using List comprehension

Algorithm

  1. Initialize an empty dictionary res.
  2. Iterate over each dictionary sub in the record list test_list.
  3. Get the values of the dictionary sub using the values() method, and update the res dictionary with these values using the update() method.
  4. Convert the resulting res dictionary to a standard dictionary using the dict() function.
  5. Print the resulting dictionary.

Python3




# initializing list
test_list = [{1 : 'gfg', 2 : 'best'}, {3 : 'for', 4 : 'geeks'}]
 
# printing original list
print("The original list is : " + str(test_list))
 
# Value Dictionary from Record List
# Using list comprehension + values() + update()
res = dict()
 
[res.update((sub.values(), )) for sub in test_list]
 
# printing result
print("The values dictionary is : " + str(dict(res)))


Output

The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}

Time Complexity: O(N*M)

The loop iterates over each dictionary in the record list once. Therefore, the time complexity of this algorithm is O(N*M), where N is the number of dictionaries in the list and M is the average size of each dictionary.
Auxiliary Space: O(N*M)

The space complexity of this algorithm is O(NM), where N is the number of dictionaries in the list and M is the average size of each dictionary. The res dictionary stores all the values from each dictionary in the list, which can take up NM space. Additionally, other variables and temporary memory used during the execution of the algorithm can also contribute to space complexity.

Method #4: Using for loop+values() method

Approach:

  1. Create an empty dictionary.
  2. Initiate a for loop to traverse list of dictionaries.
  3. Extract values of each dictionary using values() method.
  4. Make 0th index value of values list as key and 1st index value of values list as value.
  5. Display the dictionary.

Below is the implementation of the above approach:

Python3




# Python3 code to demonstrate working of
# Value Dictionary from Record List
 
# initializing list
test_list = [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
 
# printing original list
print("The original list is : " + str(test_list))
 
# Value Dictionary from Record List
res = dict()
for i in test_list:
 
    x = list(i.values())
    res[x[0]] = x[1]
 
# printing result
print("The values dictionary is : " + str(dict(res)))


Output

The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}

Time Complexity: O(M*N), where M is the length of list of dictionaries and N is the length of each dictionary
Auxiliary Space: O(M*N), where M is the number of keys and N is the number of values

Method #5: Using dictionary comprehension

Python3




# Python3 code to demonstrate working of
# Value Dictionary from Record List
 
# initializing list
test_list = [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
 
# printing original list
print("The original list is : " + str(test_list))
 
# Value Dictionary from Record List
res = {list(i.values())[0]: list(i.values())[1] for i in test_list}
 
# printing result
print("The values dictionary is : " + str(dict(res)))


Output

The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}

Time complexity: O(n), where n is the length of test_list.
Auxiliary space: O(n)

Method #6: Using map() and lambda

Python3




# Python3 code to demonstrate working of
# Value Dictionary from Record List
 
# initializing list
test_list = [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
 
# printing original list
print("The original list is : " + str(test_list))
 
# Value Dictionary from Record List using map() and lambda
res = dict(map(lambda x: (list(x.values())[0], list(x.values())[1]), test_list))
 
# printing result
print("The values dictionary is : " + str(res))


Output

The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}

Time complexity: O(n), where n is the length of test_list.
Auxiliary space: O(n)



Like Article
Suggest improvement
Previous
Next
Share your thoughts in the comments

Similar Reads