全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Python处理PDF及生成多层PDF实例代码

Python提供了众多的PDF支持库,本文是在Python3环境下,试用了两个库来完成PDF的生成的功能。PyPDF对于读取PDF支持较好,但是没找到生成多层PDF的方法。Reportlab看起来更成熟,能够利用Canvas很方便的生成多层PDF,这样就能够实现图片扫描上来的内容也可以进行内容搜索的目标。

Reportlab

生成双层PDF

双层PDF应用PDF中的Canvas概念,先画文字,最后将图片画上去,这样就是两层的PDF。

import os
# import urllib2
import time
from reportlab import platypus
from reportlab.lib.pagesizes import letter
from reportlab.lib.units import inch
from reportlab.platypus import SimpleDocTemplate, Image
from reportlab.pdfgen import canvas

image_file = "./42.png"

# Use Canvas to generate pdf
c = canvas.Canvas('reportlab_canvas.pdf', pagesize=letter)
width, height = letter

c.setFillColorRGB(0,0.77,0.77)
# say hello (note after rotate the y coord needs to be negative!)
c.drawString( 3*inch, 3*inch, "Hello World")
c.drawImage(image_file, 0 , 0)
c.showPage()
c.save()

PyPDF2

读取PDF

from PyPDF2 import PdfFileWriter, PdfFileReader

output = PdfFileWriter()
input1 = PdfFileReader(open("jquery.pdf", "rb"))

# print document info
print(input1.getDocumentInfo())

# print how many pages input1 has:
print ("pdf_document.pdf has %d pages." % input1.getNumPages())

# print page content
page_content = input1.getPage(0).extractText()
print( page_content )

# add page 1 from input1 to output document, unchanged
output.addPage(input1.getPage(0))

# add page 2 from input1, but rotated clockwise 90 degrees
output.addPage(input1.getPage(1).rotateClockwise(90))

# finally, write "output" to document-output.pdf
outputStream = open("PyPDF2-output.pdf", "wb")
output.write(outputStream)

但是PyPDF获取PDF内容有很多问题,可以看这个问题列表。文档中也有说明。

| extractText(self) | ## | # Locate all text drawing commands, in the order they are provided in the | # content stream, and extract the text. This works well for some PDF | # files, but poorly for others, depending on the generator used. This will | # be refined in the future. Do not rely on the order of text coming out of | # this function, as it will change if this function is made more | # sophisticated. | #
 | # Stability: Added in v1.7, will exist for all future v1.x releases. May | # be overhauled to provide more ordered text in the future. | # @return a unicode string object

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# python  # 生成pdf  # 生成pdf文件  # python3生成pdf  # 浅谈Python处理PDF的方法  # 是在  # 也有  # 有很多  # 这个问题  # 较好  # 后将  # 很方便  # 来完成  # 两层  # 大家多多  # 画上  # 文档  # pdf  # generate  # pagesize  # width  # height  # reportlab_canvas  # output  # setFillColorRGB 


相关文章: 如何高效配置IIS服务器搭建网站?  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  如何在服务器上三步完成建站并提升流量?  建站之星展会模版如何一键下载生成?  如何用腾讯建站主机快速创建免费网站?  在线制作视频网站免费,都有哪些好的动漫网站?  武汉网站设计制作公司,武汉有哪些比较大的同城网站或论坛,就是里面都是武汉人的?  建站主机数据库如何配置才能提升网站性能?  c# 在ASP.NET Core中管理和取消后台任务  如何用PHP工具快速搭建高效网站?  开源网站制作软件,开源网站什么意思?  如何获取开源自助建站系统免费下载链接?  如何快速搭建高效WAP手机网站?  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  建站之星如何助力企业快速打造五合一网站?  建站主机与服务器功能差异如何区分?  建站之星后台密码遗忘?如何快速找回?  打鱼网站制作软件,波克捕鱼官方号怎么注册?  高性价比服务器租赁——企业级配置与24小时运维服务  如何自定义建站之星模板颜色并下载新样式?  黑客如何通过漏洞一步步攻陷网站服务器?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  招商网站制作流程,网站招商广告语?  如何快速搭建虚拟主机网站?新手必看指南  西安大型网站制作公司,西安招聘网站最好的是哪个?  Python如何创建带属性的XML节点  建站之星代理如何获取技术支持?  活动邀请函制作网站有哪些,活动邀请函文案?  想学网站制作怎么学,建立一个网站要花费多少?  rsync同步时出现rsync: failed to set times on “xxxx”: Operation not permitted  表情包在线制作网站免费,表情包怎么弄?  建站主机是否等同于虚拟主机?  建站之星如何取消后台验证码生成?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  微信小程序 input输入框控件详解及实例(多种示例)  创业网站制作流程,创业网站可靠吗?  如何在七牛云存储上搭建网站并设置自定义域名?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  Java解压缩zip - 解压缩多个文件或文件夹实例  哈尔滨网站建设策划,哈尔滨电工证查询网站?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四)  黑客如何利用漏洞与弱口令入侵网站服务器?  重庆市网站制作公司,重庆招聘网站哪个好?  免费视频制作网站,更新又快又好的免费电影网站?  h5在线制作网站电脑版下载,h5网页制作软件?  如何用y主机助手快速搭建网站?  清除minerd进程的简单方法  Python路径拼接规范_跨平台处理说明【指导】  如何挑选高效建站主机与优质域名?  制作网站哪家好,cc、.co、.cm哪个域名更适合做网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。