【OCR】实战使用 - ocr 识别图片中的文字

实战使用 - ocr 识别图片中的文字

在Python中,OCR(Optical Character Recognition,光学字符识别)通常使用一些开源库来实现,如 pytesseract、Tesseract、PIL(Python Imaging Library)等。以下是一个基本的示例,说明如何使用pytesseract和PIL库来识别图片中的文字:

python 复制代码
import pytesseract
from PIL import Image

# 打开图片文件
image = Image.open('your_image_file_path.jpg')

# 将图片转换为灰度图像以提高识别效果
gray_image = image.convert('L')

# 使用pytesseract进行文字识别
text = pytesseract.image_to_string(gray_image)

# 打印识别出的文字
print(text)

# 如果你还需要保存处理后的图像,可以使用以下代码:
gray_image.save('processed_image.png')

在这个示例中:

  1. 首先导入所需的库。
  2. 使用Image.open()函数打开图片文件。
  3. 使用convert()函数将图片转换为灰度图像,这有助于提高OCR的识别准确率。
  4. 使用pytesseract.image_to_string()函数对图像进行文字识别,并将结果存储在text变量中。
  5. 打印识别出的文字。
  6. 如果需要保存处理后的图像(这里是灰度图像),可以使用save()函数。

注意:

  • 确保已经安装了Tesseract OCR引擎以及相关的语言数据包。你可以通过以下命令安装Tesseract(假设你已经安装了Homebrew):
bash 复制代码
brew install tesseract
  • 安装 pytesseract 库:
python 复制代码
pip install pytesseract
  • 根据你的系统和Tesseract的安装位置,可能需要在使用pytesseract时指定Tesseract的路径。
  • Tesseract的识别效果可能会受到图片质量、文字清晰度、字体类型和大小等因素的影响。对于复杂的图像或特定类型的文本,可能需要进行额外的预处理步骤或使用更高级的OCR技术。
    设置识别文字的语言
    在使用Tesseract OCR进行文字识别时,你可以通过以下方式设置识别的语言:
python 复制代码
import pytesseract

# 设置识别语言为中文(简体)
pytesseract.pytesseract.tesseract_cmd = '/usr/bin/tesseract'  # 如果需要指定Tesseract路径
language = 'chi_sim'  # 中文(简体)的语言代码

# 打开图片文件
image = Image.open('your_image_file_path.jpg')

# 将图片转换为灰度图像以提高识别效果
gray_image = image.convert('L')

# 使用pytesseract进行文字识别,同时指定识别语言
text = pytesseract.image_to_string(gray_image, lang=language)

# 打印识别出的文字
print(text)

在这个示例中,我们设置了识别语言为中文(简体),语言代码为chi_sim。你需要根据你想要识别的语言来更改这个代码。

以下是一些常见语言的Tesseract语言代码:

  • 英语:eng
  • 简体中文:chi_sim
  • 繁体中文:chi_tra
  • 法语:fra
  • 德语:deu
  • 日语:jpn
  • 韩语:kor

如果你需要识别的语言不在这个列表中,你可以通过运行Tesseract命令行工具并输入tesseract --list-langs来查看所有支持的语言。

请注意,为了识别特定语言的文字,你需要在你的系统上安装相应的Tesseract语言数据包。这些数据包通常可以通过Tesseract的安装程序或者单独下载安装。

如果你不知道如何安装Tesseract语言数据包,可以参考我之前的文章:
【OCR】 - Tesseract OCR在mac系统中安装
【OCR】 - Tesseract OCR在Windows系统中安装

相关推荐
薛定e的猫咪1 小时前
【Neural Networks 2025】TDAG 论文解读:多智能体不是重点,动态任务分解才是关键
人工智能·深度学习·计算机视觉
xiaoyaohou113 小时前
014、Neck结构改进(二):自适应空间特征金字塔(ASPP)的引入
深度学习·计算机视觉·cnn
__Wedream__3 小时前
NTIRE 2026 Challenge on Efficient Super-Resolution——冠军方案解读
人工智能·深度学习·算法·计算机视觉·超分辨率重建
春末的南方城市3 小时前
CVPR 2026 | 复旦开源首个端到端多模态矢量动画生成框架OmniLottie:UI动效革命,文本/图像一键转Lottie动画!
人工智能·深度学习·机器学习·计算机视觉·aigc
新缸中之脑3 小时前
用Gemma 4构建自托管OCR
人工智能·ocr
好家伙VCC4 小时前
**发散创新:基于Python与OpenCV的视频流帧级分析实战**在当前人工智能与计算机视觉飞速发展的背景下
java·人工智能·python·计算机视觉
_张一凡4 小时前
【文档解析】一文学懂百度千帆OCR模型细节及本地部署
深度学习·ocr·文档解析·千帆ocr·rag文档解析·qianfan-ocr
盘古开天16664 小时前
【本科毕业设计全集】资源目录
人工智能·计算机视觉·毕业设计·资源合集
shy^-^cky4 小时前
Python OpenCV 边缘检测效果对比
python·opencv·计算机视觉·边缘检测·sobel·canny·roberts
PieroPc5 小时前
销售单据 OCR 处理中心,Fastapi+Html, MiMo-V2-Omni、豆包怎理图片转Json数据
html·ocr·fastapi