Ответ 1
Простой ответ заключается в том, что в Python нет простого, точного эквивалента оператора C for
. Другие ответы покрываются с помощью инструкции Python for
с диапазоном. Если вы хотите изменить переменную цикла в цикле (и повлиять на последующие итерации), вы должны использовать цикл while
:
i = 0
while i < 7:
if someCondition(i):
i = 5
i += 1
Но в этом цикле оператор continue
не будет иметь тот же эффект, что и оператор continue
в цикле C for
. Если вы хотите, чтобы continue
работал так, как это делается на C, вам нужно выполнить оператор try
/finally
:
i = 0
while i < 7:
try:
if someCondition(i):
i = 5
elif otherCondition(i):
continue
print 'i = %d' % i
finally:
i += 1
Как вы можете видеть, это довольно уродливо. Вы должны искать более питоновский способ написать свой цикл.
UPDATE
Это только что пришло мне в голову... есть сложный ответ, который позволяет использовать обычный цикл Python for
, как цикл C-стиля, и позволяет обновлять переменную цикла путем написания пользовательского итератора. Я бы не рекомендовал это решение для любых реальных программ, но это забавное упражнение.
Пример "C-стиль" для цикла:
for i in forrange(10):
print(i)
if i == 3:
i.update(7)
Вывод:
0
1
2
3
8
9
Трюк forrange
использует подкласс int
, который добавляет метод update
. Реализация forrange
:
class forrange:
def __init__(self, startOrStop, stop=None, step=1):
if step == 0:
raise ValueError('forrange step argument must not be zero')
if not isinstance(startOrStop, int):
raise TypeError('forrange startOrStop argument must be an int')
if stop is not None and not isinstance(stop, int):
raise TypeError('forrange stop argument must be an int')
if stop is None:
self.start = 0
self.stop = startOrStop
self.step = step
else:
self.start = startOrStop
self.stop = stop
self.step = step
def __iter__(self):
return self.foriterator(self.start, self.stop, self.step)
class foriterator:
def __init__(self, start, stop, step):
self.currentValue = None
self.nextValue = start
self.stop = stop
self.step = step
def __iter__(self): return self
def next(self):
if self.step > 0 and self.nextValue >= self.stop:
raise StopIteration
if self.step < 0 and self.nextValue <= self.stop:
raise StopIteration
self.currentValue = forrange.forvalue(self.nextValue, self)
self.nextValue += self.step
return self.currentValue
class forvalue(int):
def __new__(cls, value, iterator):
value = super(forrange.forvalue, cls).__new__(cls, value)
value.iterator = iterator
return value
def update(self, value):
if not isinstance(self, int):
raise TypeError('forvalue.update value must be an int')
if self == self.iterator.currentValue:
self.iterator.nextValue = value + self.iterator.step