我偶然发现了以下代码:
for i,a in enumerate(attributes):
labels.append(Label(root, text = a, justify = LEFT).grid(sticky = W))
e = Entry(root)
e.grid(column=1, row=i)
entries.append(e)
entries[i].insert(INSERT,"text to insert")
我不明白'i,a'位和搜索谷歌有关'for'的信息是一个痛苦的屁股,当我尝试使用代码时,我得到错误:
ValueError:解包需要多于1个值
是否有人知道它的功能或与之相关的东西,我可以谷歌了解更多信息?
答案 0 :(得分:78)
你可以google“tuple unpacking”。这可以在Python的各个地方使用。最简单的是分配
>>> x = (1,2)
>>> a, b = x
>>> a
1
>>> b
2
在for循环中,它的工作方式类似。如果iterable的每个元素都是一个元组,那么你可以指定两个变量,循环中的每个元素都将被解压缩为两个。
>>> x = [(1,2), (3,4), (5,6)]
>>> for item in x:
... print "A tuple", item
A tuple (1, 2)
A tuple (3, 4)
A tuple (5, 6)
>>> for a, b in x:
... print "First", a, "then", b
First 1 then 2
First 3 then 4
First 5 then 6
枚举函数创建一个可迭代的元组,因此可以这样使用。
答案 1 :(得分:14)
枚举基本上为您提供了在for循环中使用的索引。所以:
for i,a in enumerate([4, 5, 6, 7]):
print i, ": ", a
会打印:
0: 4
1: 5
2: 6
3: 7
答案 2 :(得分:5)
以此代码为例:
elements = ['a', 'b', 'c', 'd', 'e']
index = 0
for element in elements:
print element, index
index += 1
循环遍历列表并存储索引变量。 enumerate()
做同样的事情,但更简洁:
elements = ['a', 'b', 'c', 'd', 'e']
for index, element in enumerate(elements):
print element, index
index, element
表示法是必需的,因为enumerate
会返回一个解包为两个不同变量的元组((1, 'a')
,(2, 'b')
,...)。
答案 3 :(得分:3)
[i for i in enumerate(['a','b','c'])]
结果:
[(0, 'a'), (1, 'b'), (2, 'c')]
答案 4 :(得分:1)
enumerate
函数返回一个生成器对象,在每次迭代时,生成一个包含元素索引(i
)的元组,默认情况下从0
开始编号,再加上元素本身(a
)和for
循环方便地允许您访问那些生成的元组的两个字段并为它们分配变量名。
答案 5 :(得分:1)
简短的回答,在for循环中从列表中解压缩元组是可行的。 enumerate()使用当前索引和整个当前项目创建一个元组,例如(0,('bob',3))
我创建了一些测试代码来证明这一点:
[value]
元组拆包的简单性可能是我对Python:D的最喜欢的事情之一
答案 6 :(得分:1)
您可以将 for index,value
方法与使用 ( )
的元组直接解包结合起来。如果您想在循环中设置几个相关的值,这些值可以在没有中间元组变量或字典的情况下表达,这很有用,例如
users = [
('alice', 'alice@example.com', 'dog'),
('bob', 'bob@example.com', 'cat'),
('fred', 'fred@example.com', 'parrot'),
]
for index, (name, addr, pet) in enumerate(users):
print(index, name, addr, pet)
印刷品
0 alice alice@example.com dog
1 bob bob@example.com cat
2 fred fred@example.com parrot