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

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

时间: 2017-04-21

python处理pdf 层_Python处理PDF及生成多层PDF实例代码相关推荐

  1. python功能性爬虫案例_Python使用requests及BeautifulSoup构建爬虫实例代码

    本文研究的主要是Python使用requests及BeautifulSoup构建一个网络爬虫,具体步骤如下. 功能说明 在Python下面可使用requests模块请求某个url获取响应的html文件 ...

  2. python按日期排序_python按修改时间顺序排列文件的实例代码

    python按修改时间顺序排列文件,具体代码如下所示: import os def sort_file_by_time(file_path): files = os.listdir(file_path ...

  3. python读取灰度图_Python读取MRI并显示为灰度图像实例代码

    Python读取MRI并显示为灰度图像实例代码 本文实例主要关于Python实现读取MRI(核磁共振成像)为numpy数组,使用imshow显示为灰度. 代码如下: import matplotlib ...

  4. python画棒棒糖程序_Python使用turtle库绘制小猪佩奇(实例代码)

    turtle(海龟)是Python重要的标准库之一,它能够进行基本的图形绘制.turtle图形绘制的概念诞生于1969年,成功应用于LOGO编程语言. turtle库绘制图形有一个基本框架:一个小海龟 ...

  5. python处理mat数据_python读取.mat文件的数据及实例代码

    首先导入scipy的包 from scipy.io import loadmat 然后读取 m = loadmat("F:/__identity/activity/论文/data/D001. ...

  6. 如何将PDF如何存入MySQL_如何将生成的pdf文件保存到java中的mysql数据...

    我有一个使用itext库生成pdf文件的java类.现在根据我的需要,我必须将生成的pdf文件保存到mysql数据库表中,但是我不知道该怎么做. 我的担心是:- 1.我可以在pdf表的mysql列中提 ...

  7. 二维码生成器 python excel_python生成excel的实例代码

    本文实例为大家分享了python生成excel的具体代码,供大家参考,具体内容如下 #_*_coding:utf-8_*_ import MySQLdb import xlwt from dateti ...

  8. php将pdf保存文件到本地,将生成的PDF文件存储在服务器上

    小编典典 我设法使用来解决此问题FormData(),方法如下: $(document).on("click", "#PDF", function () { v ...

  9. python怎么让x轴45°展示_python opencv实现任意角度的透视变换实例代码

    本文主要分享的是一则python+opencv实现任意角度的透视变换的实例,具体如下: # -*- coding:utf-8 -*- import cv2 import numpy as np def ...

最新文章

  1. 谈Linux的安全设置
  2. 1077: 字符串加密
  3. golang 生成 指定大小 空白文件
  4. python excel 自动化-Python控制Excel实现自动化办公
  5. (转)基于MVC4+EasyUI的Web开发框架经验总结(14)--自动生成图标样式文件和图标的选择操作...
  6. WordPress主题:自媒体二号大前端模板
  7. php报内存溢出,php为什么运行了一段时间后才报内存溢出?
  8. ocr 图片纠正_2020年10种最佳OCR软件(免费和付费工具) NO.6
  9. AOP 基本术语及其在 Spring 中的实现
  10. 正态分布的前世今生:正态分布的进一步发展
  11. 20140115-URL编码与解码
  12. 5个提高效率的编程工作环境
  13. 新手抖音直播需要什么设备;看完让你少花冤枉钱。
  14. #pragma comment (lib, ws2_32.lib) 调用报错
  15. cab补丁包离线安装命令
  16. Java并发编程面试题合集
  17. 四年级计算机教学总结,四年级信息技术教学工作总结
  18. matlab隐函数显化,怎么把隐函数显化
  19. 聊聊chatbot那些事
  20. 【常见面试题】性能测试里,压力测试、负载测试、并发测试、强度测试、容量测试,具体是什么意思

热门文章

  1. 一文详解Serverless架构模式
  2. 菜鸟数据科学家五大误区
  3. 五年,时间告诉我只有自己强大才是真的强大!
  4. 倒计时 3 天!1024 程序员节全日程曝光,105 场深度演讲点燃数字经济新时代
  5. 生产环境使用HBase,你必须知道的最佳实践
  6. 架构设计之「 微服务入门 」
  7. 如何新建java内部类_java内部类-1(内部类的定义)
  8. java 反编译class文件_用Java实现JVM第三章《解析class文件》
  9. mac mongodb可视化工具_MongoDB从立地到成佛(介绍、安装、增删改查)
  10. mysql 默认时间字段 1067,mysql替datetime类型字段设置默认值default