python实现pdf格式转换图片格式

使用python代码实现pdf转换图片格式

核心代码:

import io
from wand.image import Image
from wand.color import Color
from PyPDF2 import PdfFileReader, PdfFileWriter

memo = {}

def getPdfReader(filename):
	reader = memo.get(filename, None)

	if reader is None:

		reader = PdfFileReader(filename, strict=False)

		memo[filename] = reader

	return reader

def _run_convert(filename, page, res=120):

	idx = page + 1

	pdfile = getPdfReader(filename)

	pageObj = pdfile.getPage(page)

	dst_pdf = PdfFileWriter()

	dst_pdf.addPage(pageObj)

	pdf_bytes = io.BytesIO()

	dst_pdf.write(pdf_bytes)

	pdf_bytes.seek(0)

	img = Image(file=pdf_bytes, resolution=res)

	img.format = 'png'

	img.compression_quality = 90

	img.background_color = Color("white")

	img_path = '%s%d.png' % (filename[:filename.rindex('.')], idx)

	img.save(filename=img_path)
	print(img_path)
	img.destroy()

 

实现功能代码:

#coding:utf-8
import io
import os
import glob
from wand.image import Image
from wand.color import Color
from PyPDF2 import PdfFileReader, PdfFileWriter

memo = {}

def getPdfReader(filename):
	reader = memo.get(filename, None)
	if reader is None:
		reader = PdfFileReader(filename, strict=False)
		memo[filename] = reader
	return reader

def _run_convert(pdfile, savedfilename, page_index, index, res=120):
	pageObj = pdfile.getPage(page_index)#获取pdf的第page_index页
	dst_pdf = PdfFileWriter()
	dst_pdf.addPage(pageObj)
	pdf_bytes = io.BytesIO()
	dst_pdf.write(pdf_bytes)
	pdf_bytes.seek(0)
	img = Image(file=pdf_bytes, resolution=res)

	img.format = 'png'

	img.compression_quality = 90
	img.background_color = Color("white")

	img_path = '%s%04d.jpg' % (savedfilename, index)
	img.save(filename=img_path)
	print(img_path)
	img.destroy()

def dealPerPdf(path, file, index):
	savedfilename = path.split('/')[-1].split('-')[0] + '_'
	savedfilename = path + '/2_' + savedfilename#要保存的图片文件名

	new_path = os.path.join(path, file)
	pdfile = getPdfReader(new_path)  # 打开pdf文件句柄
	page_nums = pdfile.getNumPages()  # 获取pdf总页数

	for page_index in range(page_nums):
		# print(index)
		_run_convert(pdfile, savedfilename, page_index, index)
		index = index + 1
	return index

def getAllfiles(path):
	files = os.listdir(path)
	files.sort()
	index = 0
	for file in files:
		new_path = path + '/' + file;
		if os.path.isdir(new_path):
			getAllfiles(new_path)
		elif os.path.isfile(new_path):
			is_pdf = file.split('.')[-1]
			if is_pdf != 'pdf':
				continue
			index = dealPerPdf(path, file, index)
			index = index+1

def DealBatchPdf(path):
	getAllfiles(path)


if __name__ == '__main__':
	# path = os.getcwd()
	path = '/data/tfsong2/dangan'
	is_batch_deal = True
	if is_batch_deal:
		DealBatchPdf(path)
	else:
		filename = '001.pdf' #要处理的pdf文件名
		dealPerPdf(path, filename, 0)

即可实现pdf转图片,就不贴实际操作结果了!

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值