python pdf2image因为字体缺失导致的转换异常

Python中会采用pdf2image函数还实现pdf图像转为jpg等格式的image。

在实际使用中,发现在docker镜像中原始pdf图像转换的过程中部分文字变成了口口口情况。
已做脱敏处理
通过pdf2image函数之后得到的图片如下:
已做脱敏处理df2image内部会调用当前环境的字体目录中的字体集合,如果找不到对应的字体则会显示口口口。

解决思路:
确定是字体原因导致的,那么就需要去寻找能够使用的字体。
本次是在docker容器中运行pdf2image出现了这个问题,但是在主机运行没有这个问题,其次主机可以正常查看pdf文件,这说明本机系统上必然支持pdf对应字体的显示。因此只要找到本机的对应字体即可。

本机是linux的ubuntu环境。采用指令

apt-get fontconfig
fc-list  #查看本机安装的字体

一般字体都可以放在/usr/share/fonts中。如果不确定的话,需要通过vim /etc/share/fonts.conf这个指令查看字体放置的文件夹。

直接将字体文件复制到容器内对应的/usr/share/fonts即可使用,如果需要容器中的字体,也可以直接删除文件夹中的对应字体。
(看到其他博客提示说,加载字体需要使用fc-cache -fv指令,删除之后需要执行fc-cache -fv,我实际 测试发现不需要这两个指令也可以加载和删除模型。)

最终确定是因为缺少/usr/share/fonts/truetype/arphic/ukai.ttc和uming.ttc这两个字体导致的。

### 矢量图失真的原因分析 矢量图理论上是由数学表达式定义的几何形状组成的图像,因此无论放大或缩小都不应出现失真现象。然而,在实际操作过程中,可能会因为多种因素导致矢量图在某些场景下表现出失真效果。常见的原因包括: - **软件兼容性问题**:不同软件对矢量图形的支持程度可能有所不同,尤其是在跨平台使用时,可能导致渲染不一致[^1]。 - **导出设置不当**:当将矢量图转换为其他格式(如PDF或其他栅格化格式)时,如果未正确配置分辨率、颜色模式等参数,则可能出现质量下降的情况。 - **嵌入字体缺失**:部分矢量对象依赖特定字体显示文字内容;若目标环境中缺少这些字体,则会替换为默认字体从而改变原始布局和外观。 ### 解决方案探讨 针对上述提到的各种可能性,可以采取如下措施来减少甚至消除矢量图失真的风险: #### 方法一:优化导出流程 遵循之前描述过的具体步骤能够有效改善由空白区域引起的比例失调问题。“选中并复制图表到Word文档后再编辑”,这一过程实际上重新设置了页面边界条件,使得最终生成物更加紧凑合理。 另外需要注意的是,在执行最后一步即保存成PDF前,请务必确认选择了合适的选项以保留尽可能多的信息。例如Adobe Acrobat Professional DC提供了专门用于保持高质量打印输出的功能——“Press Quality”预设项,它包含了较高的DPI值设定以及其他有助于维持原稿清晰度的各项参数调整建议[^2]。 ```python from PIL import Image def save_as_pdf(image_path, output_pdf_path): image = Image.open(image_path) im_1 = image.convert('RGB') # Save as PDF with high resolution settings im_1.save(output_pdf_path, "PDF", resolution=300.0) save_as_pdf("example_image.png", "output_file.pdf") ``` 此脚本利用Python中的Pillow库加载一张图片文件,并将其转存为具有指定分辨率为每英寸300像素(PPI) 的PDF文档形式。通过编程方式实现自动化批量处理任务非常方便快捷[^3]。 #### 方法二:检查并修正字体相关事宜 对于那些含有大量文本标签的地图或者技术图纸来说,确保所有使用的字型都能被接收端识别至关重要。一种简单直接的办法就是在创建初始版本的时候就把所有的文字元素都转化为路径(Path),这样即使对方系统里找不到对应的TrueType 或 OpenType 文件也不会影响整体呈现效果了[^4]。 不过这样做也有缺点就是丧失了一定灵活性比如不能再轻易修改具体内容等等所以要权衡利弊之后再决定是否采用这种方法。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值