通过 Python 模块 xlwt 更改 xls 文件中的默认分页符

Ber*_*uis 5 python excel xlwt

我正在尝试使用 Python 模块 xlwt 编辑分页符。(是的,我发现了一个非常相似的问题xlwt - 如何将分页符添加到 Excel 文件?但它并没有完全解决问题)

这是一些无法按我预期工作的代码:

import xlwt

wb = xlwt.Workbook()
ws = wb.add_sheet('Report')
ws.write(0,0, '0 here')
ws.write(43,12, '12 here')
ws.horz_page_breaks = [(44,0,12),]
wb.save('sample.xls')
Run Code Online (Sandbox Code Playgroud)

它确实创建了行分页符,但列似乎有一个默认分页符(第 2 页从第 10 页的“K”列开始)。

任何人都可以解释我做错了什么或如何进行严格的分页?

PS 我被建议查看 openpyxl 库,但没有找到任何文档或示例如何设置分页符。

UPD:我发现的一些额外信息。Excel 中有一个无法删除的自动分页符(正如这里所说的http://office.microsoft.com/en-au/excel-help/insert-move-or-delete-page-breaks- in-a-worksheet-HP010021539.aspx)但只是通过拖动变成了手动分页。使用 worksheet.vert_page_break 我可以设置一个更小的(比自动的)垂直分页符。但这并不能解决我的问题。

如果有一种方法可以使用 xlwt 手动制作自动分页符,那真的很有帮助。

Ber*_*uis 5

经过几个月的研究(这不是一个紧迫的问题),我找到了一个使用xlsxwriter的解决方案查看页面设置。它不如应有的好,但是它提供了一种处理分页符的方法。下面的代码更改了工作表的默认分页符:

import xlsxwriter
import random
wb = xlsxwriter.Workbook('page_breaks.xlsx')
ws = wb.add_worksheet('Sample page')

headers = ['header1', 'header2']
# set headers
for col, header in enumerate(headers):
    ws.write(0+1, col+1, 'header'+str(col))

# let it be 300 rows of data
for row in xrange(2,302):
    ws.write(row, 1, row)

# fill table with some random data
for _ in xrange(3000):
    row = random.randrange(2, 302)
    col = random.randrange(2, 16)
    ws.write(row, col, 'X')

# print_area(), set_paper() and fit_to_pages() do the trick
ws.print_area(1, 1, 301, 15)
ws.set_paper(9)  # set A4 as page format
pages_horz = 1
pages_vert = 4
ws.fit_to_pages(pages_horz, pages_vert)

wb.close()
Run Code Online (Sandbox Code Playgroud)

如果您想在页面上有一定数量的行,您应该注意行高并根据它选择parges_vert。所以你可以使用列。

PS 我已经为 xlsxwriter 更改了 xlwt,因为我需要图表和一些其他 xlwt 没有提供的功能,此外 XlsxWriter 具有出色的文档。但这并不意味着 xlwt 不好。我猜 xlwt 有类似于 print_area()、set_paper() 和 fit_to_pages() 的东西

PPS 如果我的回答得到了赞成或者没有出现更好的东西,我会用绿色勾号标记它