可以不带i来做下面的事情吗?

for i in range(some_number):
    # do something

如果你只是想做某件事N次而不需要迭代器。


当前回答

我们有一些乐趣与以下,有趣的分享:

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

其他回答

#Return first n items of the iterable as a list
list(itertools.islice(iterable, n))

摘自http://docs.python.org/2/library/itertools.html

如果你真的想避免放一些有名字的东西(要么是OP中的迭代变量,要么是不想要的列表或不想要的生成器返回真想要的时间量),你可以这样做:

for type('', (), {}).x in range(somenumber):
    dosomething()

使用的技巧是创建一个匿名类类型(",(),{}),这将导致一个具有空名称的类,但注意它不会插入到本地或全局名称空间中(即使提供了非空名称)。然后使用该类的成员作为迭代变量,这个迭代变量是不可达的,因为它所属的类是不可达的。

我们可以使用while & yield,我们可以像这样创建自己的循环函数。在这里你可以参考官方文件。

def my_loop(start,n,step = 1):
    while start < n:
        yield start
        start += step

for x in my_loop(0,15):
    print(x)

每个人建议你使用_并不是说_经常被用作一个gettext函数的快捷方式,所以如果你想让你的软件在多种语言中可用,那么你最好避免将它用于其他目的。

import gettext
gettext.bindtextdomain('myapplication', '/path/to/my/language/directory')
gettext.textdomain('myapplication')
_ = gettext.gettext
# ...
print _('This is a translatable string.')

这里有一个随机的想法,利用(滥用?)数据模型(Py3链接)。

class Counter(object):
    def __init__(self, val):
        self.val = val

    def __nonzero__(self):
        self.val -= 1
        return self.val >= 0
    __bool__ = __nonzero__  # Alias to Py3 name to make code work unchanged on Py2 and Py3

x = Counter(5)
while x:
    # Do something
    pass

我想知道在标准库中是否有类似的东西?