6

我有一个 DataFrame,并想将其输出为 pdf。我目前正在尝试为此使用 ReportLab,但它似乎不起作用。我在这里收到一个错误:

        mytable = Table(make_pivot_table(data, pivot_cols, column_order, 'criterion'))

make_pivot_table只是使用 pandaspivot_table函数返回一个数据透视表。我得到的错误是

ValueError: <Table@0x13D7D0F8 unknown rows x unknown cols>... invalid data type

我的问题是:

  1. 有什么方法可以让 reportlab 与 DataFrames 一起工作?
  2. 如果没有,我可以使用什么包来达到同样的目的?
4

1 回答 1

3

你好,

我还需要以 .pdf 格式打印一些 Pandas DataFrame 来安排报告。我直接用 df 尝试了 ReportLab 并有一个“AttributeError:'DataFrame'对象没有属性'split'。” 我尝试使用 df.values() 并出现“TypeError:'numpy.ndarray'对象不可调用”。

当接近放弃构建 .pdf 报告的想法时,我尝试了 str(df) 并且在 .pdf 中得到了一些结果 :-) ... 代码如下所示:

import pandas as pd
from reportlab.pdfgen import canvas
PATH_OUT = "C:\\"
def pdf_df(c, testo, x, y):
    c.drawAlignedString(x,y, testo)
df = pd.DataFrame({'a':[3,4,5], 'b':[6,7,6],'c':[9,10,11]})
print df, type(df)
print''
df1 = (df['a'].groupby([df['b'], df['a']])).sum()
print df1, type(df1)
print ''
c = canvas.Canvas(PATH_OUT + 'out.pdf')
pdf_df (c, str(df), 300, 500)
pdf_df (c, str(df1), 300, 480)
c.showPage()
c.save()  

你怎么看 ?这可能有意义还是可能有一些“更聪明”的方式?

这似乎不是那么有效,我最初希望从 ReportLab 获得。看来我需要一些方法来换行..尺寸会改变......

法比奥

=====

我现在对下面的解决方案更满意,而我对上面的解决方案也不满意。

这是基于 ReportLab 网格的,它们适用于列表。因此代码将 DF 转换为列表,然后将其视为 ReportLab 网格:-)

这里是:

from reportlab.lib.styles import getSampleStyleSheet
from reportlab.platypus import *
from reportlab.lib import colors
import pandas as pd
import random

PATH_OUT = "C:\\"

elements = []
styles = getSampleStyleSheet()
doc = SimpleDocTemplate(PATH_OUT + 'Report_File.pdf')
elements.append(Paragraph("Report Title", styles['Title']))

data = [[random.random() for i in range(1,4)] for j in range (1,8)]
df = pd.DataFrame (data)
lista = [df.columns[:,].values.astype(str).tolist()] + df.values.tolist()

ts = [('ALIGN', (1,1), (-1,-1), 'CENTER'),
     ('LINEABOVE', (0,0), (-1,0), 1, colors.purple),
     ('LINEBELOW', (0,0), (-1,0), 1, colors.purple),
     ('FONT', (0,0), (-1,0), 'Times-Bold'),
     ('LINEABOVE', (0,-1), (-1,-1), 1, colors.purple),
     ('LINEBELOW', (0,-1), (-1,-1), 0.5, colors.purple, 1, None, None, 4,1),
     ('LINEBELOW', (0,-1), (-1,-1), 1, colors.red),
     ('FONT', (0,-1), (-1,-1), 'Times-Bold'),
     ('BACKGROUND',(1,1),(-2,-2),colors.green),
     ('TEXTCOLOR',(0,0),(1,-1),colors.red)]

table = Table(lista, style=ts)
elements.append(table)

doc.build(elements)

我真的很想了解其他可能的解决方案..

再见,法比奥。

于 2013-07-15T10:47:59.570 回答