pdf 转图片,多张图片合成一张图片,pdf文件转图片

import fitz
def pdf_to_img(pdf_path):
    doc = fitz.open(pdf_path)
    img_name = pdf_path.replace('.pdf', 'page-{}.png')
    for page in doc:
        pix = page.getPixmap(alpha=False)
        pix.writePNG(img_name.format(page.number))

1 . fitz库它是pymupdf中的一个模块, 使用pip install pymupdf

import fitz

doc = fitz.open('pdf的文件路径')
totaling = doc.pageCount
for pg in range(1, totaling):
  page = doc[pg]
  zoom = int(100) # 变焦
  rotate = int(0) # 旋转
  trans = fitz.Matrix(zoom / 100.0, zoom / 100.0).preRotate(rotate)
  pm = page.getPixmap(matrix=trans, alpha=False)
  pm.writePNG('图片的路径')

2. 多长图片合成一张图片,图片尺寸任意


import numpy as np
from PIL import Image
def get_merge_img(img_list):
    # 找出所有图片的最大宽和最大高
    big_w = 0
    big_h = 0
    for image_file in img_list:
        image_f = Image.open(image_file)
        w,h = image_f.size
        if w > big_w:
            big_w=w
        if h > big_h:
            big_h = h
    img_array = ''
    img = ''
    for i, v in enumerate(img_list):
        if i == 0:
            img = Image.open(v)  # 打开图片
            # 此处将单张图像进行缩放为统一大小,改为自己单张图像的平均尺寸即可
            img = img.resize((big_w, big_h), Image.ANTIALIAS)
            img_array = np.array(img)  # 转化为np array对象
        else:
            img = Image.open(v)
             # 此处将单张图像进行缩放为统一大小,改为自己单张图像的平均尺寸即可
            img = img.resize((big_w, big_h), Image.ANTIALIAS)
            img_array2 = np.array(img)
            # img_array = np.concatenate((img_array, img_array2), axis=1)  # 横向拼接
            img_array = np.concatenate((img_array, img_array2), axis=0)# 纵向拼接
            img = Image.fromarray(img_array)
    
    # 保存图片
    new_img_path = img_list[0].plit(".")[0]+'merge.jpg'
    img.save(new_img_path)

3.pdf文件转jpg

import fitz
def pdf_to_img(pdf_path):
    doc = fitz.open(pdf_path)
    img_name = pdf_path.replace('.pdf', 'page-{}.png')
    for page in doc:
        pix = page.getPixmap(alpha=False)
        pix.writePNG(img_name.format(page.number))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 要将多张PDF图片,可以使用Java的相关库来实现。以下是一个简单的步骤: 1. 首先,需要使用Java的PDF解析库来读取PDF文件的内容。可以使用Apache PDFBox、iText或PDFSam等库来实现。选择一个合适的库并将其添加到项目依赖中。 2. 接下来,需要创建一个Java程序来进行换。可以使用Java的文件操作类来读取PDF文件,然后使用PDF解析库提供的功能来解析PDF内容。 3. 使用PDF解析库的API,找到PDF中的每个页面,并将其换为图片。可以使用Java的图像处理类,如BufferedImage类或ImageIO类来处理和保存生成的图片。 4. 遍历PDF的所有页面,并依次将每个页面换为图片。可以使用循环结构来实现这一步骤。 5. 最后,保存生成的图片。可以选择将图片保存到本地文件系统中,或将其上传到服务器,或以其他形式进行处理和使用。 需要注意的是,PDF换为图片可能需要一些时间,特别是对于较大或复杂的PDF文件。因此,在换过程中,可能需要使用异步或多线程处理,以防止程序阻塞。 总之,使用Java的PDF解析库和图像处理类,可以将多张PDF文件换为图片。根据具体的需求,可以选择恰当的库和方式来实现这个功能。 ### 回答2: 要将多张PDF文件换为图片,可以使用Java中的一些开源库或工具。 其中,一个常用的库是Apache PDFBox。PDFBox是一个用于处理PDF文档的Java库,可以实现从PDF中提取文本、图像和元数据等操作。使用PDFBox将PDF换为图片需要以下步骤: 1. 引入PDFBox库。在项目的构建配置中,添加PDFBox的依赖项。 2. 创建一个PDFDocument对象,打开一个待换的PDF文件。 ```java PDDocument document = PDDocument.load(new File("path/to/input.pdf")); ``` 3. 获取PDF的总页数,并使用一个循环来遍历每一页。 4. 在每一页上创建一个BufferedImage对象,设置其宽度和高度(根据需要调整)。 ```java BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); ``` 5. 使用PDFRenderer类将当前页渲染到BufferedImage对象上。 ```java PDFRenderer renderer = new PDFRenderer(document); renderer.renderPageToGraphics(page, graphics); ``` 6. 将BufferedImage对象保存为图片文件,可以使用ImageIO类。 ```java ImageIO.write(image, "jpg", new File("path/to/output.jpg")); ``` 7. 关闭PDFDocument对象,释放资源。 ```java document.close(); ``` 需要注意的是,这只是一个基本的示例,你可以根据自己的需求和项目的规模进行适当的修改和扩展。另外,除了PDFBox,还有其他一些库和工具可以用来实现PDF图片的功能,例如iText、Aspose.PDF等,可以根据具体情况选择合适的工具。 ### 回答3: Java可以通过使用第三方库来将多张PDF图片。一个常用的库是Apache PDFBox,它是一个功能强大的Java库,可以用来处理PDF文件。 首先,我们需要在Java项目中添加Apache PDFBox库的依赖。可以在Maven或者Gradle这样的构建工具中添加依赖,或者直接将PDFBox的jar文件添加到项目的类路径中。 接下来,我们可以使用PDFBox提供的API来实现将PDF文件图片的功能。以下是一个简单的示例代码: ```java import org.apache.pdfbox.pdmodel.PDDocument; import org.apache.pdfbox.rendering.PDFRenderer; import javax.imageio.ImageIO; import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; public class PdfToImageConverter { public static void main(String[] args) { String pdfFilePath = "path/to/pdf/file.pdf"; String outputFolderPath = "path/to/output/folder/"; try { PDDocument document = PDDocument.load(new File(pdfFilePath)); PDFRenderer renderer = new PDFRenderer(document); for (int page = 0; page < document.getNumberOfPages(); page++) { BufferedImage image = renderer.renderImage(page); String outputFilePath = outputFolderPath + "page_" + (page + 1) + ".png"; ImageIO.write(image, "png", new File(outputFilePath)); } document.close(); System.out.println("PDF图片成功!"); } catch (IOException e) { e.printStackTrace(); System.out.println("PDF图片失败:" + e.getMessage()); } } } ``` 在以上代码中,我们首先加载PDF文件并创建一个`PDDocument`对象。然后,我们使用`PDFRenderer`来渲染每一页的PDF一张`BufferedImage`。最后,我们将生成的图片保存到指定的输出文件夹中。 请注意,这里将PDF成的图片格式为PNG,也可以根据需要选择其他格式如JPG。 以上是用Java将多张PDF图片的一个简单示例,可以根据实际需求进行更加复杂的操作,比如设置图片的分辨率、旋转页面等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值