我要问的问题是,我这里有一个用于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我只是想了解其中的不同之处,如果是这样的话,它应该如何工作。我觉得我遗漏了什么或者误解了什么。
发布于 2020-12-19 06:44:36
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这使得扩展程序以处理两个以上的输入变得更容易;尝试在“第一”和“第二”之后添加“第三”!)
发布于 2020-12-19 06:45:39
一旦运行程序并键入"q",是的,keep_going确实将被设置为False,但并不意味着--它已经中断了循环,它只会使keep_going等于False,因此在上,下一次迭代将停止循环。为什么会这样呢?因为它就像这个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发布于 2020-12-19 06:54:39
循环执行,直到它们的给定条件为假为止。循环只在需要时检查它的条件(程序执行移到循环的顶部)。在几乎每一种情况下,这都是在循环的整个体运行时发生的。见这里:
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 语句与 语句不同。A 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")https://stackoverflow.com/questions/65367298
复制相似问题