此问题是对以下问题的跟踪:Openpyxl: TypeError - Concatenation of several columns into one cell per row
我要做什么: 我想将每行从F列到M的单元格连接起来,并将连接后的值放入E列,如下所示。必须同时对所有行执行此操作。
输入:
A B C D E F G H .. M
....... E1 90 2A .. 26
....... 0 80 F8 ..
输出:
A B C D E F G H .. M
....... E1902A..26
....... 080F8..
代码:
def concat_f_to_m():
for row_value in range(1, sheet.max_row+1):
values=[]
del values[:]
for row in sheet.iter_rows(min_col=6, max_col=14, min_row=row_value, max_row=row_value):
for cell in row:
if cell.value != None:
values.append(str(cell.value))
else:
del values[:]
pass
sheet[f'E{row_value}'].value= ''.join(values)
concat_f_to_m()
我也将max列设置为N列(14),因为最长的代码一直持续到M列,并且我想在没有找到条目的情况下停止循环以退出并加入列表的项。我无法克服以下问题:尽管打印了值列表,但仅显示该行的项目,但没有将其写到单元格中。 您能否提示我如何通过在特定行加入值列表来连接所有行?谢谢!
答案 0 :(得分:0)
正确的实现:
def concat_f_to_m():
for row_value in range(1, sheet.max_row+1):
values=[]
del values[:]
for row in sheet.iter_rows(min_col=6, max_col=14, min_row=row_value, max_row=row_value):
for cell in row:
if cell.value != None:
values.append(str(cell.value))
sheet[f'E{row_value}'].value= ''.join(values)
else:
del values[:]
break
concat_f_to_m()