可以不带i来做下面的事情吗?
for i in range(some_number):
# do something
如果你只是想做某件事N次而不需要迭代器。
可以不带i来做下面的事情吗?
for i in range(some_number):
# do something
如果你只是想做某件事N次而不需要迭代器。
当前回答
可以使用_11(或任何数字或其他无效标识符)来防止与gettext发生名称冲突。任何时候你使用下划线+无效标识符,你得到一个可以在for循环中使用的虚拟名称。
其他回答
我们有一些乐趣与以下,有趣的分享:
class RepeatFunction:
def __init__(self,n=1): self.n = n
def __call__(self,Func):
for i in xrange(self.n):
Func()
return Func
#----usage
k = 0
@RepeatFunction(7) #decorator for repeating function
def Job():
global k
print k
k += 1
print '---------'
Job()
结果:
0
1
2
3
4
5
6
---------
7
你可能正在寻找
for _ in itertools.repeat(None, times): ...
这是Python中迭代次数最快的方法。
为未使用的值赋值的一般习惯用法是将其命名为_。
for _ in range(times):
do_stuff()
我大体上同意以上给出的解决方案。即:
在for循环中使用下划线(2行或更多行) 定义一个普通的while计数器(3行或更多行) 用__nonzer__实现声明一个自定义类(更多行)
如果要像#3中那样定义一个对象,我建议实现protocol for with keyword或apply contextlib。
此外,我还提出另一种解决办法。它是一个3行代码,并不是非常优雅,但它使用itertools包,因此可能会感兴趣。
from itertools import (chain, repeat)
times = chain(repeat(True, 2), repeat(False))
while next(times):
print 'do stuff!'
在这个例子中,2是循环迭代的次数。Chain包装了两个重复迭代器,第一个是有限的,第二个是无限的。记住,这些是真正的迭代器对象,因此它们不需要无限内存。显然,这比解决方案#1要慢得多。除非作为函数的一部分编写,否则可能需要清理times变量。
如果你真的想避免放一些有名字的东西(要么是OP中的迭代变量,要么是不想要的列表或不想要的生成器返回真想要的时间量),你可以这样做:
for type('', (), {}).x in range(somenumber):
dosomething()
使用的技巧是创建一个匿名类类型(",(),{}),这将导致一个具有空名称的类,但注意它不会插入到本地或全局名称空间中(即使提供了非空名称)。然后使用该类的成员作为迭代变量,这个迭代变量是不可达的,因为它所属的类是不可达的。