python处理pdf文件_Python3操作pdf文件之ReportLab

一说到pdf文件,大家应该都很熟悉吧,特别是那些经常在网上搜索某本书pdf版的人。别装了,那些人当中应该就有你吧?--开玩笑的,知道你是一向只买正版纸质版的人。

买正版纸质的人?好像扯远了。好吧,言归正传,咱说一下Python3处理pdf相关的内容。

Python3处理pdf的第3库挺多的,当然,处理其它文件的库也多。这次咱就说下耳熟能详、久经战场并被最、最、最被看好的ReportLab。

1

若要想要获得ReportLab的支持,得先安装它的开发包。打开【终端】,输入那句,闭着眼,都会输错的命令:pip3 install reportlab。稍等一会会,就能安装完了,究竟多长时间,你可以用手机记一下时间,如果实在闲得无聊的话。

9825bc315c6034a80e4f9297a8f9835008237661.jpeg?token=638aad499bd227b356d81d51e46b84c9&s=9E827C22130F514918F584DB000080B1

2

安装好开发包后,咱就来写写如何生成pdf文件并送给经常下载它同类的你。来,打开你喜欢的开发工具,输入以下代码。

from reportlab.pdfgen import canvas

def write_pdf():

c = canvas.Canvas("demo1.pdf")

# 注意,这里用英文,不是因为我英文好,而是默认不支持中文

c.drawString(200, 500, "Hello PDF")

# 不信默认不支持中文,咱走着瞧

c.drawString(200, 550, "你好,PDF文件")

c.showPage()

c.save()

write_pdf()

ac345982b2b7d0a2f4257d3da905bc0d49369a95.jpeg?token=f41fdf0b4395f787c844d27d602b4300&s=7DAC3D7257384C230EDDC5DE000080B1

3

见到上面的中文乱码,整个心情都不好了,倘若不解决,以后就不用混Python圈了。若要想ReportLab支持中文,可以去下载SimSun.ttf字体,并把它放在/ python3.7/site-packages/reportlab/fonts文件夹下,至于Python的安装路径得按你的实际情况来。当然,中文字体并非一定要用SimSun的,只是这个可以支持,我就用它来说明而已。

from reportlab.pdfgen.canvas import Canvas

from reportlab.pdfbase import pdfmetrics

from reportlab.pdfbase.ttfonts import TTFont

def write_pdf():

# 注册字体

pdfmetrics.registerFont(TTFont("SimSun", "SimSun.ttf"))

c = Canvas("demo1.pdf")

# 应用注册的字体

c.setFont("SimSun", 14)

c.drawString(200, 550, "自从PDF支持中文以后,整个人都变了")

c.save()

write_pdf()

37d12f2eb9389b5038f935a0e6df2fd9e6116e29.jpeg?token=f2df3aec641745a661cbc7be1ba41f13&s=FDA03D72137A642D1C74D4CA000080B1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值