如何在 Python 2.7 中将 while 语句重写为 if 语句?



我编写了一个脚本,用于在Excel文档中搜索"X",当它找到"X"时,它将与"X"关联的第一列和第一行复制到CSV文件中。

有人告诉我,有一种更好的方法来使用"if"语句来做到这一点。不太确定如何。

代码如下:

import xlrd
import csv
###Grab the data from sheet 1
def get_row_values(workSheet, row):
to_return = []
num_cells = myWorksheet.ncols - 1
curr_cell = -1
while curr_cell < num_cells:
curr_cell += 1
cell_value = myWorksheet.cell_value(row, curr_cell)
to_return.append(cell_value)
return to_return
file_path = 'foo.xlsx'
output = []
#Write the data
myWorkbook = xlrd.open_workbook(file_path)
myWorksheet = myWorkbook.sheet_by_name('foosheet')
num_rows = myWorksheet.nrows - 1
curr_row = 0
column_names = get_row_values(myWorksheet, curr_row)
#print("TOTAL ENTRIES:") 
#print len(column_names)
#print("-----")
framework_name = myWorksheet.cell(0,2)
framework_version = myWorksheet.cell(0,3)
while curr_row < num_rows:
curr_row += 1 
row = myWorksheet.row(curr_row)
this_row = get_row_values(myWorksheet, curr_row)
x = 0
while x <len(this_row):
if this_row[x] == 'x':
output.append(['', fooname, foo_version, 
foo_names[x], foo_row[0]])
myData = [["foo1", "foo2", 
"foo3", "foo4", "foo5"]]
myFile = open('./results/barTemp.csv', 'w')
with myFile:
writer = csv.writer(myFile)
writer.writerows(myData)
writer.writerows(output)
x += 1
#print output

myFile.close()
myWorkbook.release_resources()

它不一定更好。仍然具有相同的运行时复杂性。

不同之处在于更紧凑的生产线:

例如,您可以更改

而 x <镜头(this_row(:>

对于 this_row 中的 X:

但我看到您使用"x"索引来查找column_names[x],因此另一种方法可能会更好,例如

对于范围内的 x(len(this_row((:

最新更新