用变量打破循环 - Python
Break loop with variable - Python
我想以更紧凑的形式编写我的循环。当我有这种形式的代码时,一切正常:
a=-1
while a <0:
user_move()
if (nastede[1]==X) and (nastede[2]==X) and (nastede[3]==X):
print("Game Over")
break
print("END")
但是当我尝试使用这种形式的代码时,我的循环没有中断:
y=(nastede[1] and nastede[2] and nastede[3])
a=-1
while a <0:
user_move()
if y == X:
print("Game Over")
break
print("END")
为什么我在第二种情况下的循环没有在 y
中用 nastede[]
中断?
修改后(所有代码):
nastede=[" ", " ", " ", " ", " ", " ", " ", " ", " "]
X="X"
def list_global():
global nastede
print(" ",nastede[0],"| ",nastede[1]," | ",nastede[2]," ")
print("---------------")
print(" ",nastede[3],"| ",nastede[4]," | ",nastede[5]," ")
print("---------------")
print(" ",nastede[6],"| ",nastede[7]," | ",nastede[8]," ")
def user_move():
a=-1
while a<0:
move_hum=int(input("Write a number from 1 to 8 ?\n"))
if (nastede[move_hum] != X) and (nastede[move_hum] != O):
nastede[move_hum] = "X"
list_global()
break
else:
print("Write different number")
a=-1
while a <0:
user_move()
if all(map(lambda x: x == X, nastede)):
print("Game Over")
break
print("END")
您的条件 y=(nastede[1] and nastede[2] and nastede[3])
会将 y
绑定到 True
,除非 X
是 True
,否则不会像您期望的那样进行评估。
最好结合使用 all
和 map
:
...
if all(map(lambda x: x == X, nestede))
...
这里有一个minimal example
编辑:
因为 all
检查所有这些代码都会失败,因为你只检查从索引 1
到 3
,为此使用 slice
:
...
if all(map(lambda x: x == X, nestede[1:4]))
...
记住 python 切片不包含尾部 [x,y)
还有更好的:
....
if all(i == X for i in nestede):
...
...
(nastede[1]==X) and (nastede[2]==X) and (nastede[3]==X)
和 (nastede[1] and nastede[2] and nastede[3])
不一样。在第一个语句中,每个值都需要等于 X
才能获得真值。但是在第二个代码中,如果所有值都是真值,即使它们不等于 X
,那么表达式将 return True
。
我想以更紧凑的形式编写我的循环。当我有这种形式的代码时,一切正常:
a=-1
while a <0:
user_move()
if (nastede[1]==X) and (nastede[2]==X) and (nastede[3]==X):
print("Game Over")
break
print("END")
但是当我尝试使用这种形式的代码时,我的循环没有中断:
y=(nastede[1] and nastede[2] and nastede[3])
a=-1
while a <0:
user_move()
if y == X:
print("Game Over")
break
print("END")
为什么我在第二种情况下的循环没有在 y
中用 nastede[]
中断?
修改后(所有代码):
nastede=[" ", " ", " ", " ", " ", " ", " ", " ", " "]
X="X"
def list_global():
global nastede
print(" ",nastede[0],"| ",nastede[1]," | ",nastede[2]," ")
print("---------------")
print(" ",nastede[3],"| ",nastede[4]," | ",nastede[5]," ")
print("---------------")
print(" ",nastede[6],"| ",nastede[7]," | ",nastede[8]," ")
def user_move():
a=-1
while a<0:
move_hum=int(input("Write a number from 1 to 8 ?\n"))
if (nastede[move_hum] != X) and (nastede[move_hum] != O):
nastede[move_hum] = "X"
list_global()
break
else:
print("Write different number")
a=-1
while a <0:
user_move()
if all(map(lambda x: x == X, nastede)):
print("Game Over")
break
print("END")
您的条件 y=(nastede[1] and nastede[2] and nastede[3])
会将 y
绑定到 True
,除非 X
是 True
,否则不会像您期望的那样进行评估。
最好结合使用 all
和 map
:
...
if all(map(lambda x: x == X, nestede))
...
这里有一个minimal example
编辑:
因为 all
检查所有这些代码都会失败,因为你只检查从索引 1
到 3
,为此使用 slice
:
...
if all(map(lambda x: x == X, nestede[1:4]))
...
记住 python 切片不包含尾部 [x,y)
还有更好的:
....
if all(i == X for i in nestede):
...
...
(nastede[1]==X) and (nastede[2]==X) and (nastede[3]==X)
和 (nastede[1] and nastede[2] and nastede[3])
不一样。在第一个语句中,每个值都需要等于 X
才能获得真值。但是在第二个代码中,如果所有值都是真值,即使它们不等于 X
,那么表达式将 return True
。