百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

用Python制作数据报告:如何自动生成PDF格式的报告?

off999 2025-07-23 17:39 5 浏览 0 评论

最近在琢磨数据分析工作的自动化,手动做报告真是太费劲啦!试过用Python整了个自动生成PDF报告的小工具,效果还不错。今天就聊聊怎么用Python把数据处理、可视化和PDF生成一条龙搞定。

reportlab:PDF生成的得力助手

reportlab是Python里特别好用的PDF生成库,搭配起来做报表简直不要太方便。装它超简单:

pip install reportlab

来个最基础的PDF示例:

from reportlab.pdfgen import canvas
from reportlab.lib.pagesizes import A4

# 新建个PDF文件

pdf = canvas.Canvas(“简单报告.pdf”, pagesize=A4)

pdf.drawString(100, 750, “这是我的第一份Python生成的报告”)

pdf.save()

温馨提示:记得指定pagesize,不然默认页面可能有点小

数据可视化:让报告更生动

光有文字多没意思,加点图表才够味儿。matplotlib这个库画图超好用:

import matplotlib.pyplot as plt
import numpy as np
# 造点数据
sales = [120, 150, 180, 210, 165]
months = ['1月', '2月', '3月', '4月', '5月']
# 画个柱状图
plt.figure(figsize=(8, 6))
plt.bar(months, sales)
plt.title('销售数据统计')
plt.savefig('sales_chart.png')

组合拳:图文并茂的报告

把文字和图片都塞进PDF里:

from reportlab.lib.utils import ImageReader
def create_report():
    pdf = canvas.Canvas(“完整报告.pdf”, pagesize=A4)
    # 加标题
    pdf.setFont(“Helvetica-Bold”, 16)
    pdf.drawString(100, 750, “2024年第一季度销售报告”)
    # 放图片
    img = ImageReader('sales_chart.png')
    pdf.drawImage(img, 50, 400, width=500, height=300)
    # 加说明文字
    pdf.setFont(“Helvetica”, 12)
    pdf.drawString(100, 350, “从图表可以看出,销售额整体呈上升趋势”)
    pdf.save()

进阶玩法:自动处理表格

要是数据多,可以用platypus模块处理表格:

from reportlab.platypus import SimpleDocTemplate, Table, TableStyle
from reportlab.lib import colors
def create_table_report():
	  doc = SimpleDocTemplate(“表格报告.pdf”, pagesize=A4)
		# 准备表格数据
    data = [
        ['月份', '销售额', '同比增长'],
      	['1月', '120万', '15%'],
        ['2月', '150万', '25%'],
        ['3月', '180万', '20%']
		]
    # 设置表格样式
    table = Table(data)
		table.setStyle([
      	('GRID', (0, 0), (-1, -1), 1, colors.black),
    		('BACKGROUND', (0, 0), (-1, 0), colors.grey)
    ])
    doc.build([table])

温馨提示:表格样式可以自己调整,比如改颜色、字体大小啥的

完整代码示例:

from reportlab.pdfgen import canvas
from reportlab.lib.pagesizes import A4
from reportlab.lib.utils import ImageReader
from reportlab.platypus import SimpleDocTemplate, Table, TableStyle
from reportlab.lib import colors
import matplotlib.pyplot as plt
import numpy as np

def generate_chart():
		sales = [120, 150, 180, 210, 165]
		months = ['1月', '2月', '3月', '4月', '5月']
		plt.figure(figsize=(8, 6))
		plt.bar(months, sales)
		plt.title('销售数据统计')
		plt.savefig('sales_chart.png')
		plt.close()

def create_full_report():
		# 先生成图表
    generate_chart()

		# 创建PDF
    pdf = canvas.Canvas(“数据分析报告.pdf”, pagesize=A4)
	
		# 添加内容
    pdf.setFont(“Helvetica-Bold”, 16)
		pdf.drawString(100, 750, “2024年第一季度销售报告”)
		img = ImageReader('sales_chart.png')
		
		pdf.drawImage(img, 50, 400, width=500, height=300)
		pdf.setFont(“Helvetica”, 12)
		pdf.drawString(100, 350, “销售情况分析说明:”)
		pdf.drawString(120, 330, “1. 销售额持续增长”)
		pdf.drawString(120, 310, “2. 第四月份达到峰值”)
		pdf.save()

# 运行试试看
create_full_report()

搞定啦!代码运行完就能看到生成的PDF报告。要是想改报告样式,调整一下坐标和格式就好。试着改改参数,做出自己想要的报告样式吧!

相关推荐

一文搞清 Python 中方法和函数之间的区别

在我们使用Python的过程中,经常涉及到方法和函数,那他们有什么不同吗?在本文中,让我们通过示例了解Python中方法和函数之间的区别。Python函数Python函数是一系列以特定顺序...

Python 数据分析 + 可视化实战:5 分钟出图表,老板看了直点赞

还在用Excel做数据分析?效率太低了!同样一份销售数据,同事用Python半小时出报告,图表炫酷还能自动更新;你用Excel捣鼓大半天,稍微改点数据就得重新做图。今天教你用Python...

Python每日一库之Pendulum(python penup)

关于日期处理,Python提供了许多库,例如标准库datetime、第三方库dateutil、Arrow等。在这篇文章中,我想介绍我个人最喜欢的库pendulum,它使用非常方便,它可以满足...

Python计算两个日期相差天数 M + ACT/360模式,银行计算利息用

一般银行在计算计息的时候,都会用到M+ACT/360模式,也就是满1个月按30天计算,不足一个月按实际天数计算。一年算360天。例如:计算20151018到20190817相差的天数,201...

Python 之 MySql 每日一练 32——查询每门课程的平均成绩

一、表名和字段–1.学生表student(s_id,s_name,s_birth,s_sex)–学生编号,学生姓名,出生年月,学生性别–2.课程表course(c_id,c_name,t...

用Python制作数据报告:如何自动生成PDF格式的报告?

最近在琢磨数据分析工作的自动化,手动做报告真是太费劲啦!试过用Python整了个自动生成PDF报告的小工具,效果还不错。今天就聊聊怎么用Python把数据处理、可视化和PDF生成一条龙搞定。repor...

Github 1.2k star,一个好用的 Python 库-pyexcel!

大家好,今天为大家分享一个好用的Python库-pyexcel。Github地址:https://github.com/pyexcel/pyexcelpyexcel是一个功能强大的Python...

使用python写一个简单的到期事件钉钉提醒功能

前言:学习python第3天需求:简单的事件提醒功能版本:python3.9、mysql5.71、现在mysql建一个表event_remindCREATETABLE`event_remind`...

python定时任务最强框架APScheduler详细教程

APScheduler定时任务上次测试女神听了我的建议,已经做好了要给项目添加定时任务的决定了。但是之前提供的四种方式中,她不知道具体选择哪一个。为了和女神更近一步,我把我入行近10年收藏的干货免费拿...

解放双手,一键运行!Python每日自动生成数据日报

对于一个企业来说,高层看意义,中层看结论,基层看落地,数据日报、周报、月报可以监控销售个人在实际执行过程中的销售动态,而数据季度报、年报可以反映一个销售策略是否与实际的业务场景切合。可见数据日报在我们...

Python模块datetime、calendar、logging、argparse、re用法

datetime模块:提供日期和时间相关的功能。importdatetime#获取当前日期和时间current_time=datetime.datetime.now()#格式化日期...

python入门到脱坑正则表达式—re.search()函数

re.search()是Python正则表达式模块re中的核心函数之一,用于在字符串中搜索匹配指定模式的第一个位置。与re.match()不同,它不限制匹配必须从字符串开头开始。基本语法...

python3从零学习-5.2.1、日历相关模块calendar

源代码:Lib/calendar.py这个模块让你可以输出像Unixcal那样的日历,它还提供了其它与日历相关的实用函数。默认情况下,这些日历把星期一当作一周的第一天,星期天为一周的最后一...

DAY6-step7 Python 示例说明CALENDAR

Python中的Calendar模块具有Calendar类,该类允许基于日期,月份和年份来计算各种任务。最重要的是,Python中的TextCalendar和HTMLCalendar类允许您编辑日历...

Python 数据分析——Pandas 时间序列

Pandas提供了表示时间点、时间段和时间间隔等三种与时间有关的类型,以及元素为这些类型的索引对象,并提供了许多时间序列相关的函数。一、时间点、时间段、时间间隔Timestamp对象从Python标准...

取消回复欢迎 发表评论: