是否有可能在Python中创建一个字典理解(用于键)?

如果没有列表推导式,你可以这样使用:

l = []
for n in range(1, 11):
    l.append(n)

我们可以将其缩短为一个列表推导式:l = [n for n in range(1,11)]。

但是,假设我想将字典的键值设置为相同的值。 我可以:

d = {}
for n in range(1, 11):
     d[n] = True # same value for each

我试过了:

d = {}
d[i for i in range(1, 11)] = True

但是,我在for上得到了一个SyntaxError。

此外(我不需要这部分,但只是想知道),你可以将字典的键设置为一堆不同的值,像这样:

d = {}
for n in range(1, 11):
    d[n] = n

这在字典理解中是可能的吗?

d = {}
d[i for i in range(1, 11)] = [x for x in range(1, 11)]

这还会在for上引发SyntaxError。


当前回答

字典推导式非常类似于列表推导式,但是我们在它的末尾得到了一个字典,所以我们需要分配键值对,而不仅仅是值。

假设我们有一个用户列表,其中每个用户信息都存储在一个元组中。我们有一个包含四个用户元组的列表。在其中,它们有一个ID,每个用户的唯一标识号码、用户名和密码。

因此,我们想要创建用户名到用户信息的映射。 这是你会经常做的事情,尤其是当你做网络应用之类的事情时。

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循环,以确保您在输入时使用了正确的用户名。

其他回答

>>> {i:i for i in range(1, 11)}
{1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, 10: 10}

我真的很喜欢@mgilson注释,因为如果你有两个可迭代对象,一个对应于键,另一个对应于值,你还可以做以下事情。

keys = ['a', 'b', 'c']
values = [1, 2, 3]
d = dict(zip(keys, values))

D = {'a': 1, 'b': 2, 'c': 3}

考虑这个使用字典理解来计算单词在列表中的出现次数的例子

my_list = ['hello', 'hi', 'hello', 'today', 'morning', 'again', 'hello']
my_dict = {k:my_list.count(k) for k in my_list}
print(my_dict)

结果是

{'again': 1, 'hi': 1, 'hello': 3, 'today': 1, 'morning': 1}

你不能这样散列。 试试这个,它使用元组

d[tuple([i for i in range(1,11)])] = True

字典推导式非常类似于列表推导式,但是我们在它的末尾得到了一个字典,所以我们需要分配键值对,而不仅仅是值。

假设我们有一个用户列表,其中每个用户信息都存储在一个元组中。我们有一个包含四个用户元组的列表。在其中,它们有一个ID,每个用户的唯一标识号码、用户名和密码。

因此,我们想要创建用户名到用户信息的映射。 这是你会经常做的事情,尤其是当你做网络应用之类的事情时。

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循环,以确保您在输入时使用了正确的用户名。