我正在尝试在特定单元格中打印内容。 我知道在将内容提取到输出之前要检查的单元格。 我正在使用多个IF语句:

if lineCount == 5:
if line[0]:
print line[0], 'A5'
OPfound = 1
break
if line[1]:
print line[1], 'B5'
OPfound = 1
break
if lineCount == 4:
if line[0]:
print line[0], 'A4'
OPfound = 1
break
if line[1]:
print line[1],'B4'
OPfound = 1
break

输出格式如下: - 提取的内容,单元格编号

我想要做的是首先检查A5中是否有任何内容 - 如果有内容然后提取它...否则检查B5中的内容 - 如果有内容然后提取它...否则检查A4中的内容

我得到B5和A4的输出......但不是A5

如果A5,B5和A4中没有内容,我如何检查B4中的内容...

请扩展您的代码以包含有关line和lineCount的信息。 此外,你的缩进是远离。

什么是"细胞"?

我希望当你粘贴它时,你的缩进已经搞砸了,即使它确实有效。

你可以print"A{}".format(linecount)来压缩一些代码

您是否对break实际执行的内容或if语句的更多详细信息进行了任何研究?

Darian Moody在他的博客文章中有一个很好的解决方案:

a = 1
b = 2
c = True
rules = [a == 1,
b == 2,
c == True]
if all(rules):
print("Success!")

当给定iterable中的所有元素都为true时,all()方法返回True。如果不是,则返回False。

您可以在此处的python文档中阅读更多相关内容以及此处的更多信息和示例。

(我也在这里用这个信息回答了类似的问题 - 如何在python中为一个if语句提供多个条件)

首先,您不要使用break结束Python代码块。 Python在看到你缩进后会结束一个代码块,如下所示:

if condition: //or any other statement that needs a block
//code goes here
//end of block

break语句用于终止它可以找到的最内层循环。如果您在循环下运行该代码,break语句可能会产生一些严重的错误。

无论如何,有一种更传统的方法来测试多种条件下的东西。没有break语句的当前设置应该有效,但我建议您使用if...elif...else语句。这是格式:

if condition:
//run if true
elif condition:
//run if first expression was false, and this is true
elif condition:
//run if second expression was false, and this is true
... (you get the idea)
else:
//run if all other expressions are false

请记住,在Python找到一个在这样的语句中为真的表达式之后,它将运行相应的代码块并忽略所有其他块。

希望这可以帮助!

break不允许你离开if条款,如果那是你确实试图突破的条款。这里的技巧是删除break语句并用elif替换你的第二个if,如下所示:

if lineCount == 5:
if line[0]:
print line[0],'A5'
OPfound = 1
elif line[1]:
print line[1],'B5'
OPfound = 1
if lineCount == 4:
if line[0]:
print line[0],'A4'
OPfound = 1
elif line[1]:
print line[1],'B4'
OPfound = 1

这样,如果第一个语句失败,则每个lineCount子句只运行第二个if语句,而不是每次都失败。

这几乎给了我所要求的......但是如果A5中有内容我不想要读A4 ...现在我得到了A4和A5的输出......这将是什么解决方案?

@safwan只是在第二个外面if if statement是elif:例如elif lineCount==4:

elif意味着,如果之前的if或elif条件不正确(并且只有不是),那么检查一下。 elif代表其他如果。 还有else,它涵盖了您未包含的任何条件。 在if语句中放置if语句是一种嵌套形式(嵌套if语句)。