修复 Excel 打印或者转为 PDF 时的图片拉伸问题

月朗星稀😚娜不一样 于 2023-09-05 发布 浏览量

问题

Excel 中的图片在打印或者转为 PDF 后看起来都在宽度方向上被拉长了。遇到这个问题很久了,之前也用百度、必应、Google 搜索过解决办法,但是中文搜索结果中大多是推荐各种软件、驱动的,并没有真的解决问题,就一直这么凑合着用。

今天突然想起来,Excel 这么多年一直有这个问题,也许国外也有讨论,就用英文搜索了一下。一番查找,终于顺着这个问答中 fhaidacher 的回答:

Why does Excel still stretch graphics in width when printing

在国外这个 Excel 论坛找到了:

Excel will not print images at correct height/width!!

原因

这应该是由于Excel对于不同的字体有不同拉伸处理,导致 Excel 打印出来字体虽然正常显示,但图片被错误拉伸了。选择正确的字体主题,图片就不会被错误拉伸了。

特别说明一下,即使设置了不同的字体主题,在 Excel 文件中仍然可以随意为单元格中文字设置不同的字体。

解决方法

办法 1:简单办法

最简单的办法是更换主题或者字体主题:

在 Excel 页面布局选项卡的“主题”下面,选择“大都会”主题,或者“都会”字体主题:

image

如果是较早版本的 Excel,有 Metro (都会)字体主题的话,可以直接选择字体主题。 如果是 Office 365 (Microsoft 365),字体主题下面没有 Metro(都会),可以选择“主题”下面的 Metropolis(大都会)主题。

办法 2:自定义字体主题

将主题改为“大都会”后发现,字体主题不是列表中的几个,选择自定义主题,发现西文字体被设置为 Calibri Light,中文字体被设置为 宋体。

image

个人觉得用 宋体 显示数字和字母实在太难看:

image

根据上面帖子提到的,将字体设置为 Segoe UI 也可以正常比例打印图像,于是自定义将中文字体设置为 Segoe UI。 行、列的数字和字母显示和打印、转PDF的图片比例问题就都解决了。

image

分析测试

实际使用上述方法后发现,使用 宋体 字体主题和使用 Segoe UI 字体主题打印或者转换PDF后,还是有细微区别。使用一个正方形图形测试发现,使用大部分字体主题时,打印或者转为PDF后,图像会被在宽度方向上拉伸。 而使用 宋体 主题时,实际上会在高度方向上被轻微拉伸。使用 Segoe UI 最接近原始比例,但在宽度方向仍有非常轻微的拉伸。