python PIL 图片放大的问题

发布于 2022-09-04 17:55:53 字数 712 浏览 33 评论 0

尝试用pytesseract来识别一些图片:
图片描述

原始图片尺寸较小,用pytesseract无法识别,开始尝试用 Mac 自带的预览工具来放大尺寸 ,发现可以正常识别了,然后尝试用 PIL 来放大图片,代码如下:

images.resize((1985, 336),Image.ANTIALIAS).save('/images', quality=95,dpi=(72, 72))

问题是,通过 PIL 放大的图片不能被pytesseract 正常识别,我对比了两张图片的信息,如下图:
图片描述

发现除了图片尺寸不同外,其他信息都是相同的,但是就是无法被pytesseract正常识别,所以求教如何用 PIL 放大出可以正常被pytesseract识别的图片(其他工具也可以)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

尾戒 2022-09-11 17:55:53

你可以尝试改变tesseract的-psm参数:

image = Image.open('ocr.png')
image.show()
for p in range(4,14):
    print(p, '-', pytesseract.image_to_string(image, config="-psm {}".format(p)))

输出如下:

4 - 3 4'1 4'1 I] I]
5 - D
D
d.
d.
_...I._
6 - 3 4'1 4'1 I] I]
7 - 3 4'1 4'1 I] I]
8 - 34400
9 - 34400
10 - W
11 - 3

£1

I1

I]

I]
12 - 
13 - 34400

如果图片只有数字你也能尝试用tessedit_char_whitelist:

pytesseract.image_to_string(image, config="-psm 8 -c tessedit_char_whitelist=1234567890")
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文