在xlwings中创建和命名表

时间:2019-08-13 13:38:48

标签: python excel xlwings

我正在尝试使用xlwings从我的某些Python代码中连接Excel,不幸的是,仅找到了关于访问/重新格式化已经存在的 Excel表而不是创建新Excel表的stackoverflow线程或文档。从头开始。

编辑:基于David Zemen的答案添加的解决方案(可以使用here的ListObject属性的其他getter和setter方法。

import xlwings

df = ... # initialising some pandas DataFrame

book = xlwings.Book()
ws = book.sheets.active
ws.range("A1").options(index=False).value = df

# TODO: Create table
# downside: does not seem to be possible to define multiple tables
#           within a Sheet (based on explicit ranges)
tbl = ea_sheet.api.ListObjects.Add(1) 


# TODO: Set the name/formatting of the table
tbl.DisplayName = "tabname"  # sets the tablename

我知道我可以使用ws.range("A1").expand('table')扩展范围选择,并且知道可以使用range的.name属性将它们定义为命名范围。

但是,xlwings是否提供任何从范围创建表的方法(类似于在Excel UI中使用“首页-格式化为表”)?

1 个答案:

答案 0 :(得分:2)

我不确定xlwings是否直接支持ListObjects的创建,但是由于它公开了api,因此您可以尝试以下方法:

xlSrcRange = 1
xlYes = 1
ws.range("A1").options(index=False).value = df
tbl_range = ws.range("A1").expand('table')
ws.api.ListObjects.Add(xlSrcRange, tbl_range, xlListObjectHasHeaders=xlYes)

不幸的是,这似乎不起作用,并且默默地失败了。

import xlwings as xw
import pandas as pd
import numpy as np
# creating a dummy dataframe
data = np.array(np.random.randint(0,100,(3,4)))
columns = ['A','B','A','C']
index = ['Row 1', 'Row 2', 'Row 3']
frame = pd.DataFrame(data, index=index, columns=columns)
book = xw.Book()
ws = book.sheets.active
ws.range("A1").options(index=False).value = frame
tbl_range = ws.range("A1").expand('table')
ws.api.ListObjects.Add(1, tbl_range)  ## This line fails, but no error is raised. 

我怀疑将xlwings范围作为第二个参数传递给Add方法会出现问题。

我尝试了其他一些操作,如果我们省略了range参数,则在运行ws.api调用时似乎可以正常工作(警告:当前ActiveCell /选择必须在表区域/使用范围内) ):

ws.api.ListObjects.Add(1)

enter image description here

最后,我能够使其与ListObjects.Add方法一起使用,但是使用.api传递有效的Excel范围而不是xlwings范围:

ws.api.ListObjects.Add(1, ws.api.Range(tbl_range.address))