Home > Backend Development > Python Tutorial > How to print all key-value pairs in a dictionary in Python

How to print all key-value pairs in a dictionary in Python

王林
Release: 2023-05-05 21:22:05
forward
4609 people have browsed it

To print all key-value pairs in the dictionary:

  • Use the dict.items() method to get a view of the dictionary items.

  • Use for to loop through the view.

  • Use the print() function to print each key-value pair.

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}

for key, value in my_dict.items():
    # name jiyik
    # age 30
    # language Python
    print(key, value)


print(list(my_dict.keys()))  # ????️ ['name', 'age', 'language']

print(list(my_dict.values()))  # ????️ ['jiyik', 30, 'Python']
Copy after login

dict.items Method returns a new view of dictionary items ((key, value) pairs).

# ????️ [('name', 'jiyik'), ('age', 30), ('language', 'Python')]
print(list(my_dict.items()))
Copy after login

If we need to format keys and values ​​in any way, use formatted string literals.

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}

for key, value in my_dict.items():
    # name=jiyik
    # age=30
    # language=Python
    print(f'{key}={value}')
Copy after login

Formatted string literals f-strings Let us include an expression in a string by prepending f in front of it.

var1 = 'fql'
var2 = 'jiyik'

result = f'{var1}{var2}'
print(result)  # ????️ fqljiyik
Copy after login

Make sure to enclose the expression in braces - {expression}.

We can use the dict.keys() and dict.values() methods to print the keys and values ​​of the dictionary.

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}

print(list(my_dict.keys()))  # ????️ ['name', 'age', 'language']

print(list(my_dict.values()))  # ????️ ['jiyik', 30, 'Python']
Copy after login

dict.keys Method returns a new view of the dictionary keys.

dict.values Method returns a new view of dictionary values.

If we need to concatenate the key-value pairs of the dictionary into a string, please use the str.join() method.

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}

result = ', '.join(f'{key}: {value}' for key, value in my_dict.items())

# ????️ name: jiyik, age: 30, language: Python
print(result)
Copy after login

We pass the generator expression to the str.join() method.

Generator expressions are used to perform certain operations on each element or to select a subset of elements that meet a condition.

In each iteration, we format the key-value pair using a formatted string literal.

str.join method takes an iterable object as a parameter and returns a string that is the concatenation of the strings in the iterable object.

The string on which this method is called is used as a separator between elements.

We use commas and spaces as separators between key-value pairs, but you can use any other separator.

The following is an example using the newline character (\n) as the delimiter.

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}


result = '\n'.join(f'{key}: {value}' for key, value in my_dict.items())

# name: jiyik
# age: 30
# language: Python
print(result)
Copy after login

When concatenated with the newline \n character delimiter, the dictionary's key-value pairs are printed on separate lines.

We can also use the iterable * unpacking operator with the sep parameter to print all key-value pairs in the dictionary.

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}


# ('name', 'jiyik')
# ('age', 30)
# ('language', 'Python')
print(*my_dict.items(), sep='\n')
Copy after login

* The iterable unpacking operator enables us to unwrap iterable objects in function calls, comprehensions, and generator expressions. The

sep argument is the separator between the arguments we pass to print().

print('fql', 'jiyik', sep='')  # ????️ fqljiyik

print('fql', 'jiyik')  # ????️ fql jiyik
Copy after login

By default, the sep parameter is set to spaces.

We can use the json.dumps() method to pretty print the key-value pairs in the dictionary.

import json

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}


# {
#     "name": "jiyik",
#     "age": 30,
#     "language": "Python"
# }
print(json.dumps(my_dict, indent=4))
Copy after login

json.dumps Method converts a Python object into a JSON-formatted string.

If indent is set to a non-negative integer, JSON array elements or object members will be pretty-printed using the specified indentation level.

We use an indentation level of 4 spaces, but you can use any other positive integer.

We can set the sort_keys parameter to True to sort the keys of the dictionary when serializing to JSON.

import json

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}


# {
#     "age": 30,
#     "language": "Python",
#     "name": "jiyik"
# }
print(json.dumps(my_dict, indent=4, sort_keys=True))
Copy after login

sort_keys The argument can be used to sort the output alphabetically by keys.

We can also use the pprint() method to beautifully print the key-value pairs in the dictionary.

from pprint import pprint

my_dict = {
    'name': 'jiyik',
    'age': 30,
    'language': 'Python'
}


# {'name': 'jiyik',
#  'age': 30,
#  'language': 'Python'}
pprint(my_dict, width=1, sort_dicts=False)
Copy after login

pprint.pprint Method prints the formatted representation of the object.

We set the width parameter to 1 to set the maximum number of characters required per line to 1.

This way, all key-value pairs in the dictionary will be printed on different lines.

We also set the sort_dicts parameter to False to prevent the method from sorting the keys in the dictionary alphabetically.

When sort_dicts is set to False, the dictionary's items are printed in insertion order.

The above is the detailed content of How to print all key-value pairs in a dictionary in Python. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:yisu.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template