我正在尝试将列表写入 Excel,该列表包含几列。
我在下面包含了我的代码。它似乎只提取第一个值。我对 python 还很陌生,我缺少什么?
代码:
import win32com.client as win32
#
Z = [3,4,6,8,9,11,40]
Q = ['x','y','z','e','g','AA','BB']
excel = win32.gencache.EnsureDispatch('Excel.Application')
wb = excel.Workbooks.Add()
ws = wb.Worksheets.Add()
ws.Name = "MyNewSheet"
ws.Range(ws.Cells(1,1),ws.Cells(1,2)).Value = ['Z','Q']
for i,e in enumerate (Z):
ws.Range("A2:A8").Value = [ i for i in (Z)]
for i,e in enumerate (Z):
ws.Range("B2:B8").Value = [ i for i in (Q)]
wb.SaveAs('beta.xlsx')
excel.Application.Quit()
最佳答案
它似乎想要将值写入行。因此,这会将写入重新对齐为按行:
代码:
import win32com.client as win32
Z = [3, 4, 6, 8, 9, 11, 40]
Q = ['x', 'y', 'z', 'e', 'g', 'AA', 'BB']
excel = win32.gencache.EnsureDispatch('Excel.Application')
wb = excel.Workbooks.Add()
ws = wb.Worksheets.Add()
ws.Name = "MyNewSheet"
ws.Range("A1:B1").Value = ['Z', 'Q']
ws.Range("A2:B8").Value = list(zip(Z, Q))
wb.SaveAs('beta.xlsx')
excel.Application.Quit()
结果:
Z Q
3 x
4 y
6 z
8 e
9 g
11 AA
40 BB
关于python - 如何使用 win32com 模块填充 Excel 中的列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42617549/