Эмулировать цикл выполнения в Python? - PullRequest
675 голосов
/ 13 апреля 2009

Мне нужно эмулировать цикл do-while в программе Python. К сожалению, следующий простой код не работает:

list_of_ints = [ 1, 2, 3 ]
iterator = list_of_ints.__iter__()
element = None

while True:
  if element:
    print element

  try:
    element = iterator.next()
  except StopIteration:
    break

print "done"

Вместо «1,2,3, готово» выводится следующий вывод:

[stdout:]1
[stdout:]2
[stdout:]3
None['Traceback (most recent call last):
', '  File "test_python.py", line 8, in <module>
    s = i.next()
', 'StopIteration
']

Что я могу сделать, чтобы перехватить исключение «остановка итерации» и сделать перерыв цикл правильно?

Пример того, почему такая вещь может понадобиться, показан ниже как псевдокод.

Конечный автомат:

s = ""
while True :
  if state is STATE_CODE :
    if "//" in s :
      tokens.add( TOKEN_COMMENT, s.split( "//" )[1] )
      state = STATE_COMMENT
    else :
      tokens.add( TOKEN_CODE, s )
  if state is STATE_COMMENT :
    if "//" in s :
      tokens.append( TOKEN_COMMENT, s.split( "//" )[1] )
    else
      state = STATE_CODE
      # Re-evaluate same line
      continue
  try :
    s = i.next()
  except StopIteration :
    break

Ответы [ 13 ]

4 голосов
/ 13 апреля 2009

Почему бы тебе просто не сделать

for s in l :
    print s
print "done"

1 голос
/ 06 мая 2018

Если вы находитесь в сценарии, когда вы зацикливаетесь, когда ресурс недоступен или что-то похожее, что вызывает исключение, вы можете использовать что-то вроде

import time

while True:
    try:
       f = open('some/path', 'r')
    except IOError:
       print('File could not be read. Retrying in 5 seconds')   
       time.sleep(5)
    else:
       break
1 голос
/ 13 апреля 2009

Посмотрите, поможет ли это:

Установите флаг в обработчике исключений и проверьте его перед началом работы с s.

flagBreak = false;
while True :

    if flagBreak : break

    if s :
        print s
    try :
        s = i.next()
    except StopIteration :
        flagBreak = true

print "done"
...