最近用python做的一个将PDF每一页拆分成图片的功能,遇到特别大的PDF文件时处理就会很吃力,电脑会卡死有时候甚至处理失败!!!求教大佬们有没有好的解决办法
1条回答 默认 最新
- 多鱼的夏天 2021-02-26 10:46关注
可以使用ImageMagick来实现,完美解决你遇到的问题
ImageMagick
是Linux上超强大、功能超丰富的图片处理的命令行工具。
而ImageMagick
在做PDF相关的工作时,是基于Ghostscript
进行处理的。所以两个都要安装。首先确保本机已经安装ImageMagick与Ghostscript,
Mac安装:
brew install ghostscript imagemagick
Ubuntu安装:
sudo apt-get install -y ghostscript imagemagick # on error: sudo apt-get update
安装好后,命令行里就可以调用ImageMagick的一系列命令了,包括:
- convert
常用命令有:
#JPG图片转为PNG图片 $ convert image.jpg image.png #将图片缩放为50%大小 $ convert image.png -resize 50% image2.png #将图片缩放为指定长宽 $ convert image.png -resize 640x480 image2.png #横向合并图片 $ convert image1.png image2.png image3.png +append image123.png
PDF转图片
用
imagemagick
将pdf转成图片(不是提取图片)的命令是:$ convert sample.pdf sample.jpg
命令非常简单,速度也极快。但是在PDF转图片的过程中,如果不加任何设置直接
convert xx.pdf xx.png
这样的转换,效果可是非常之差# 默认转换:图片大小几乎与pdf相同 $ convert sample.pdf sample.jpg # resize设置:无论resize 100还是3000,都没有清晰化 $ convert -resize 3000 sample.pdf sample.jpg # quality设置:完全没有作用 $ convert -quality 100% sample.pdf sample.jpg # verbose+density+quality+flatten+sharpen转换:也就大概还原了80%的清晰度 $ convert -verbose -density 150 -trim -quality 100 -flatten -sharpen 0x1.0 sample.pdf sample.jpg # density 300转换:100%还原,但是文件增大10倍 $ convert -density 300 -trim -quality 100 sample.pdf sample.jpg # geometry 转换:100%还原,文件增大7倍 $ convert -geometry 1600x1600 -density 200x200 -quality 100 sample.pdf sample.jpg
解决 无用评论 打赏 举报
悬赏问题
- ¥15 Fluent udf 编写问题
- ¥15 求合并两个字节流VB6代码
- ¥15 Pyqt 如何正确的关掉Qthread,并且释放其中的锁?
- ¥30 网站服务器通过node.js部署了一个项目!前端访问失败
- ¥15 WPS访问权限不足怎么解决
- ¥15 java幂等控制问题
- ¥15 海湾GST-DJ-N500
- ¥15 氧化掩蔽层与注入条件关系
- ¥15 Django DRF 如何反序列化得到Python对象类型数据
- ¥15 多数据源与Hystrix的冲突