派
你好,
我还需要以 .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)
我真的很想了解其他可能的解决方案..
再见,法比奥。