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

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

itomcoil 2025-05-30 15:12 4 浏览

最近在琢磨数据分析工作的自动化,手动做报告真是太费劲啦!试过用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中一个看似简单却暗藏玄机的操作——字符串格式化。你是不是还在用%s拼凑变量?或者写了无数个format()却依然被同事吐槽代码太“复古”?别急,这篇干货带你解锁三种神...

Python Unicode字符串编程实用教程

Unicode是现代文本处理的基础,本教程将介绍Python中的Unicode字符串处理,涵盖从基础概念到高级应用等。一、Unicode基础概念1.1Unicode与编码核心概念:Unicode:字...

殊途同归 python 第 6 节:字符串的使用

字符串作为Python的基础数据之一,以下是字符串的几种最常用情形,直接上代码1.声明字符串a="helloworld"b='竹杖芒鞋轻胜马,谁怕,一蓑烟雨任平生...

python爬虫字符串定位开始跟结束(find方法的使用)

python爬虫采集的时候会需要对采集的内容进行处理行为,处理什么?简单的说就是处理多余的HTML代码跟确定文章标题跟结尾,还有内容区间,方法如下:首先先是定位,我们先假设我们采集到了一批数据,数据里...

python 入门到脱坑 基本数据类型—字符串string

以下是Python字符串(String)的入门详解,包含基础操作、常用方法和实用技巧,适合初学者快速掌握:一、字符串基础1.定义字符串#单引号/双引号s1='hello's...

python字符串知识点总结

Python字符串知识点总结1.字符串基础字符串是不可变的序列类型可以用单引号(')、双引号(")或三引号('''或""")创建三引号...

在 Python 中使用 f-String 格式化字符串

在Python3.6中引入的f字符串提供了一种既简洁又可读的字符串格式新方法。f字符串的正式名称为格式化字符串文字,是以f或F为前缀的字符串,其中包含大括号内的表达式。这些表达式在...

零起点Python机器学习快速入门-4-3-字符串常用方法

Python中字符串的多种操作。包括去除字符串首尾的空格和特定字符、字符串的连接、查找字符在字符串中的位置、字符串之间的比较、计算字符串的长度、大小写转换以及字符串的分割。通过这些操作,我们可以对字...

Python 中 字符串处理的高效方法,不允许你还不知道

以下是Python中字符串处理的高效方法,涵盖常用操作、性能优化技巧和实际应用场景,帮助您写出更简洁、更快速的代码:一、基础高效操作1.字符串拼接:优先用join()代替+原因:join()预...

Python字符串详解与示例

艾瑞巴蒂字符串的干货来了,字符串是程序中最常见的数据类型之一,用来表示数据文本,下面就来介绍下字符串的特性,操作和方法,和一些示例来吧道友:1.字符串的创建在python中字符串可以永单引号(...

Python中去除字符串末尾换行符的方法

技术背景在Python编程中,处理字符串时经常会遇到字符串末尾包含换行符的情况,如从文件中读取每一行内容时,换行符会作为字符串的一部分被读取进来。为了满足后续处理需求,需要将这些换行符去除。实现步骤1...

表格编程之争:Python VS VBA?Excel用户:新编程语言才真香!

Python和VBA哪个更好用?Python和VBA是两种不同的编程语言,它们都有自己的特点和优缺点。在表格编程方面,VBA在Excel中的应用非常广泛,可以通过宏来实现自动化操作和数据处理,也可以通...

用Python把表格做成web可视化图表

Python中有一个streamlit库,Streamlit的美妙之处在于您可以直接在Python中创建Web应用程序,而无需了解HTML、CSS或JavaScrip,今天我们就用st...

使用 Python 在 PowerPoint 演示文稿中创建或提取表格

PowerPoint中的表格是一种以结构化格式组织和呈现数据的方法,类似于Excel或Word等其他应用程序中表格的使用方式。它们提供了一种清晰简洁的方式来显示信息,使您的受众更容易消化和理...

用python实现打印表格的方法

最近在做表格输出的任务,一般有两种方法实现在控制台打印,一种是根据表格的输出规则自己写代码实现,另外一种是安装python的第三方依赖包prettytable实现这个效果。方法1:根据表格规则写代码...