Python While 循环突破问题

时间:2020-12-19 06:33:20

标签: python while-loop flags

所以我对 Python 和一般编程还很陌生。我的问题是关于我在这里的 while 循环标志。这有效,但不像我认为的那样。我想我不理解某些东西,所以如果有人能够解释,那就太好了。

根据我的理解,只要满足我的条件之一,这就会跳出循环。因此,如果我输入“q”,它应该会中断并停止循环。但发生的情况是它不断循环,然后爆发。所以它通过最后一个提示并打印异常。

(Python 版本为 3.8.5)

# Statement that tells the user what we need.
print("Enter two numbers and I will tell you the sum of the numbers.")
# Lets the user know they can press 'q' to exit the program.
print("Press 'q' at anytime to exit.")

keep_going = True

# Loop to make the program keep going until its told to stop.
while keep_going:
    # Prompt for user to input first number and store it in a variable.
    first_number = input("First number: ")
    # Create a break when entering the first number.
    if first_number == 'q':
        keep_going = False
    # Prompt for user to input second number and store it in a variable.
    second_number = input("Second number: ")
    # Create a break when entering the second number.
    if second_number == 'q':
        keep_going = False
    # Exception for non integers being input "ValueError"
    try:
        # Convert input to integers and add them. 
        # storing the answer in a variable.
        answer = int(first_number) + int(second_number)
    except ValueError:
        # Tell the user what they did wrong.
        print("Please enter a number!")
    else:    
        # Print the sum of the numbers
        print(f"\nThe answer is: {answer}")

使用此代码它会像我预期的那样立即爆发。

while True:
    first_number = input("First number: ")
    if first_number == 'q':
        break
    second_number = input("Second number: ")
    if second_number == 'q':
        break

我只是想了解有什么区别,以及它是否应该这样工作。我觉得我错过了什么或误解了什么。我试过查这个,但还没有找到答案。

提前致谢!

5 个答案:

答案 0 :(得分:11)

while 循环的条件只在循环体的迭代之间进行检查,因此如果在循环中间更改条件,则当前迭代将在循环终止之前完成。如果您想立即中断循环,您需要break(无论条件如何都会自动中断循环)或continue(跳转到下一次迭代,因此,如果条件不再为真,则将终止循环)。

当您想停止循环时,将 while True:break 一起使用通常比尝试通过设置和取消设置标志来控制循环要简单得多。

FWIW,与其复制和粘贴代码来输入两个数字,并有两种不同的方式来跳出循环,我可能会将所有这些都放入一个函数中并用 Exception 来打破循环,像这样:

print("Enter two numbers and I will tell you the sum of the numbers.")
print("Press 'q' at anytime to exit.")


def input_number(prompt: str) -> int:
    """Ask the user to input a number, re-prompting on invalid input.
    Exception: raise EOFError if the user enters 'q'."""
    while True:
        try:
            number = input(f"{prompt} number: ")
            if number == 'q':
                raise EOFError
            return int(number)
        except ValueError:
            print("Please enter a number!")


while True:
    try:
        numbers = (input_number(n) for n in ("First", "Second"))
        print(f"The answer is: {sum(numbers)}")
    except EOFError:
        break

这样可以更轻松地扩展程序以处理两个以上的输入;尝试在“第一”和“第二”之后添加“第三”! :)

答案 1 :(得分:5)

一旦你运行程序并输入“q”,确实keep_going将被设置为False但它并不意味着它已经打破了循环,它只会使 keep_going 等于 False 因此在 NEXT ITERATION 将停止循环。这是为什么?因为它会像这样 while keep_going: -> while False: 所以因为它不是 True 因此不再执行程序。

现在根据您提到的目标。您可以通过这种方式添加 break

if first_number == 'q':
    keep_going = False
    break
# Prompt for user to input second number and store it in a variable.
second_number = input("Second number: ")
# Create a break when entering the second number.
if second_number == 'q':
    keep_going = False
    break

我也想建议采用这种方式,它只是在代码上发生的事情方面更具体,但这当然取决于您。

first_number = input("First number: ")
# Create a break when entering the first number.
if first_number == 'q':
    keep_going = False
    break
# Prompt for user to input second number and store it in a variable.
# Create a break when entering the second number.
else:
    second_number = input("Second number: ")
    if second_number =='q':
        keep_going = False
        break

答案 2 :(得分:2)

While 循环执行,直到给定的条件为假。 循环只会在需要时检查其条件(程序执行移至循环的顶部)。在几乎所有情况下,当循环的整个主体运行时都会发生这种情况。看这里:

keep_going = True

while keep_going:
  keep_going = False
  # keep_going is False, but this will still print once
  # because the loop has not checked its condition again.
  print("Will execute once")

“将执行一次” 即使在 keep_going 设置为 False 后也会打印一次。发生这种情况是因为 while 循环在其整个主体运行之前不会重新检查其条件。

但是,break 语句不同。break 语句无论如何都会导致循环立即退出。

keep_going = True

while keep_going:
  break # Exits the while loop immediately. The condition is not checked.
  print("Will never print")

在这里,即使 keep_going 一直是 True,也没有打印任何内容。 break 使循环退出,无论条件如何。

continue 语句会将程序执行移回循环的开头,并再次检查您的条件。

在这个例子中,continue 将程序执行发送回循环的开始。由于 keep_going 设置为 False,因此不会打印任何内容,因为 while 循环将在实现其条件评估为 false 后退出。

keep_going = True

while keep_going:
  keep_going = False
  continue
  print("Will never print")

答案 3 :(得分:2)

首先,希望您在学习 Python 时玩得开心!

两种方式都可以工作并停止循环,但有一个区别:

  1. 在第一种方法中,您将 keep_going 变量更改为 false,因此,当 while 循环发现 keep_going 已变为 { 时,循环将停止{1}}。但是,检查仅在循环结束时发生(在您的情况下,是在您完成 Falseexcept 部分之后),即使您输入 {,循环也不会立即停止{1}} 用于您的变量 else

  2. 在第二个解决方案中,您在 Python 中使用 q 关键字,以便在为 first_number 输入 break 后立即脱离循环。

从技术上讲,如果您想在检测到 q 时立即中断循环,则需要 first_number,否则,将 break 设置为 q 如果您希望完成整个循环,但不要在下一轮再次运行。

在场景 1 中,即使您输入了 keep_going,结果也是如此

False

将始终显示,但不适用于场景 2。

答案 4 :(得分:1)

这是您的脚本的一种稍微不同的方法:

def main():
    print("Enter two numbers and I will tell you the sum of the numbers.")
    print("Press 'q' at anytime to exit.")
    val = []
    while True:

        check_value = lambda x: 'quit' if x.lower() == 'q' or x.lower() == 'quit' else int(x)
        if not val:
            value = input("First number: ")
        elif len(val) == 2:
            answer = sum(val)
            print(f"\nThe answer is: {answer}")
            print('==='*15 + ' < ' + f'PROGRAM RESTARTING' + ' > ' + '==='*15)

            val[:] = []
            continue
        else:
            value = input("Second number: ")


        try:
            check_ = check_value(value)
            val.append(check_)
        except ValueError:
            print("Please enter a number!")
            continue
        finally:
            if check_ == 'quit':
                print('Program is stopping....')
                break
            else:
                pass


if __name__ == '__main__':
    main()

它会随时检查用户的输入,无论是 'q' 'Q' 或 ('quit' 或 'QUIT') 还是任意组合或大写字母,因为运行检查 x.lower()

我建议你看一下 realpython.com 尤其是“he Python break and continue Statements”这一段。

长话短说:

  • 使用 Break 在任何给定时间终止循环。

  • 使用 continue 回滚你离开的地方并再次重复循环(如果值不是 Int,我在我的代码中使用它)

  • 使用 pass 保持循环不间断运行。