字典推导很像列表推导,但我们在它的末尾得到一个字典,所以我们需要分配键值对而不是只分配值。
假设我们有一个用户列表,其中每个用户信息都存储在一个元组中。所以我们有一个包含四个用户元组的列表。在其中,他们有一个 ID、每个用户的唯一标识号、用户名和密码。
因此,我们要创建用户名到用户信息的映射。这是您经常会做的事情,尤其是当您在做诸如 Web 应用程序之类的事情时。
users = [
(0, "Bob", "password"),
(1, "code", "python"),
(2, "Stack", "overflow"),
(3, "username", "1234"),
]
username_mapping = {user[1]: user for user in users}
userid_mapping = {user[0]: user for user in users}
print(username_mapping)
"""
Why can this be helpful?
Well, imagine you know a user's username,and you want to get their information out.
You just access, let's say, "Bob," in your username_mapping, and you've got the information out.
"""
print(username_mapping["Bob"]) # (0, "Bob", "password")
# -- Can be useful to log in for example --
username_input = input("Enter your username: ")
password_input = input("Enter your password: ")
_, username, password = username_mapping[username_input]
if password_input == password:
print("Your details are correct!")
else:
print("Your details are incorrect.")
所以这是一个使用这个结构执行某种登录的例子,这个字典理解。
这真的很有帮助,因为它使您不必在此处执行另一个 for 循环,以确保您使用正确的用户名进行输入。