我正在尝试在特定单元格中打印内容。 我知道在将内容提取到输出之前要检查的单元格。 我正在使用多个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语句)。