使用Python开发一个图像标注与OCR识别工具

2025-03-06 17:50

本文主要是介绍使用Python开发一个图像标注与OCR识别工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《使用Python开发一个图像标注与OCR识别工具》:本文主要介绍一个使用Python开发的工具,允许用户在图像上进行矩形标注,使用OCR对标注区域进行文本识别,并将结果保存为Excel文件,感兴...

图像标注和OCR(光学字符识别)工具的代码进行详细分析。该工具允许用户在图像上进行矩形标注,使用 OCR 对标注区域进行文本识别,并将结果保存为 Excel 文件。同时,用户可以保存和加载标注,清除标注,以及裁剪图像等。

项目简介

这个图像标注和OCR工具的功能主要包括:

  • 加载图像并显示在界面上。
  • 允许用户在图像上绘制矩形框,以标注感兴趣的区域。
  • 在标注区域内执行OCR识别,并显示识别的文本。
  • 将OCR识别结果保存为Excel文件。
  • 保存和加载用户的标注数据(jsON格式)。
  • 提供裁剪、清除标注、重置图像等功能。

1. 图像加载与显示

首先,程序会扫描指定文件夹中的图像文件(支持的格式包括 .png, .jpg, .jpeg, .bmp, .tiff),并显示在界面的图像面板中。

self.image_files = [f for f in os.listdir(folder_path) 
                    if f.lower().endswith(('.png', '.jpg', '.jpeg', '.bmp', '.tiff'))]

通过 wx.ListBox 组件显示图像文件的列表,用户可以点击选择一个文件,然后加载并显示它:

file_path = os.path.join(self.folder_path, jsfilename)
self.original_image = cv2.imdecode(np.fromfile(file_path, dtype=np.uint8), cv2.IMREAD_COLOR)
self.original_image = cv2.cvtColor(self.original_image, cv2.COLOR_BGR2RGB)

这段代码使用 OpenCV 读取图像,并转换颜色空间以适应 wxpython 显示。

2. 矩形标注

用户可以在图像上绘制矩形框,标记感兴趣的区域。程序通过鼠标事件(按下、移动、松开)来绘制和更新矩形框:

def on_mouse_down(self, event):
    """鼠标按下开始绘制矩形"""
    if self.displayed_image is not None:
        self.start_point = event.GetPosition()
        self.drawing = True

def on_mouse_move(self, event):
    """鼠标移动时更新矩形"""
    if self.drawing and self.displayhttp://www.chinasem.cned_image is not None:
        self.image_panel.Refresh()

​​​​​​​def on_mouse_up(self, event):
    """鼠标松开完成矩形绘制"""
    if self.drawing and self.displayed_image is not None:
        end_point = event.GetPosition()
        # 确保矩形方向正确
        x1 = min(self.start_point.x, end_point.x)
        y1 = min(self.start_point.y, end_point.y)
        x2 = max(self.start_point.x, end_point.x)
        y2 = max(self.start_point.y, end_point.y)
        orig_rect = self.co编程nvert_to_original_coords((x1, y1, x2, y2))
        self.rectangles.append(orig_rect)
        self.drawing = False
        self.image_panel.Refresh()

在 on_mouse_down 中,用户点击图像开始绘制矩形框,on_mouse_move 用于实时更新矩形的形状,on_mouse_up 在用户松开鼠标时完成矩形的绘制。

3. OCR识别

标注完成后,用户可以点击“识别”按钮,程序会对标注区域进行OCR识别。OCR处理通过 pytesseract 库实现:

text = pytesseract.image_to_string(
    pil_image, 
    lang='chi_sim',  # 中文简体
    config='--psm 6 --oem 3'  # 更精确的文本块处理
)

识别结果会显示在文本框中,并且可以将识别的结果保存为Excel文件:

if ocr_results:
    df = pd.DataFrame({'识别区域': range(1, len(ocr_results) + 1), '识别文本': ocr_results})
    output_path = os.path.join(self.folder_path, f'{self.current_filename}_ocr_results.xlsx')
    df.to_excel(output_path, index=False, engine='openpyxl')

使用 pandas 库将识别结果保存为Excel文件,方便后续查看和处理。

4. 标注的保存与加载

程序还允许用户将标注区域保存为 JSON 格式,以便下次加载时使用。这是通过以下方式实现的:

annotations_data = {
    'filename': self.current_filename,
    'rectangles': self.rectangles
}
json_path = os.path.join(self.folder_path, f'{self.current_filename}_annotations.json')
with open(json_path, 'w', encoding='utf-8') as f:
    json.dump(annotations_data, f)

标注文件会根据图像的文件名命名,以便与图像文件对应。加载标注时,程序会读取 JSON 文件并恢复之前的标注状态:

with open(json_path, 'r', encoding='utf-8') as f:
    annotations_data = json.load(f)
if annotations_data['filename'] == self.current_filename:
    self.rectangles = annotations_data['rectangles']

5. 裁剪与重置图像

裁剪功能允许用户裁剪图像的选定区域。用户完成矩形绘制后,点击“裁剪”按钮,程序会根据最后一个矩形进行图像裁剪:

cropped = self.current_image[y1:y2, x1:x2].copy()

如果需要重置图像,用户可以点击“重置图像”按钮,程序将恢复到原始图像状态。

6. UI组件与布局

wxPythpythonon 的布局管理使得界面整洁易用。主界面分为文件列表、图像显示区域和操作按钮区域三个部分。文件列表用于选择图像,图像显示区域展示图像并允许标注,按钮区域提供裁剪、标注、OCR识别等操作。

file_list_sizer = wx.BoxSizer(wx.VERTICAL)
self.file_listbox = wx.ListBox(panel, choices=sjavascriptelf.image_files, style=wx.LB_SINGLE)
file_list_sizer.Add(self.file_listbox, 1, wx.EXPAND | wx.ALL, 10)

通过 BoxSizer 管理不同控件的布局,使得界面更加模块化和灵活。

运行结果

使用Python开发一个图像标注与OCR识别工具

以上就是使用Python开发一个图像标注与OCR识别工具的详细内容,更多关于Python图像标注与OCR识别的资料请关注China编程(www.chinasem.cn)其它相关文章!

这篇关于使用Python开发一个图像标注与OCR识别工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153664

相关文章

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

Python中如何控制小数点精度与对齐方式

《Python中如何控制小数点精度与对齐方式》在Python编程中,数据输出格式化是一个常见的需求,尤其是在涉及到小数点精度和对齐方式时,下面小编就来为大家介绍一下如何在Python中实现这些功能吧... 目录一、控制小数点精度1. 使用 round() 函数2. 使用字符串格式化二、控制对齐方式1. 使用

Python如何快速下载依赖

《Python如何快速下载依赖》本文介绍了四种在Python中快速下载依赖的方法,包括使用国内镜像源、开启pip并发下载功能、使用pipreqs批量下载项目依赖以及使用conda管理依赖,通过这些方法... 目录python快速下载依赖1. 使用国内镜像源临时使用镜像源永久配置镜像源2. 使用 pip 的并

使用Apache POI在Java中实现Excel单元格的合并

《使用ApachePOI在Java中实现Excel单元格的合并》在日常工作中,Excel是一个不可或缺的工具,尤其是在处理大量数据时,本文将介绍如何使用ApachePOI库在Java中实现Excel... 目录工具类介绍工具类代码调用示例依赖配置总结在日常工作中,Excel 是一个不可或缺的工http://

基于.NET编写工具类解决JSON乱码问题

《基于.NET编写工具类解决JSON乱码问题》在开发过程中,我们经常会遇到JSON数据处理的问题,尤其是在数据传输和解析过程中,很容易出现编码错误导致的乱码问题,下面我们就来编写一个.NET工具类来解... 目录问题背景核心原理工具类实现使用示例总结在开发过程中,我们经常会遇到jsON数据处理的问题,尤其是

Java之并行流(Parallel Stream)使用详解

《Java之并行流(ParallelStream)使用详解》Java并行流(ParallelStream)通过多线程并行处理集合数据,利用Fork/Join框架加速计算,适用于大规模数据集和计算密集... 目录Java并行流(Parallel Stream)1. 核心概念与原理2. 创建并行流的方式3. 适

Python如何实现读取csv文件时忽略文件的编码格式

《Python如何实现读取csv文件时忽略文件的编码格式》我们再日常读取csv文件的时候经常会发现csv文件的格式有多种,所以这篇文章为大家介绍了Python如何实现读取csv文件时忽略文件的编码格式... 目录1、背景介绍2、库的安装3、核心代码4、完整代码1、背景介绍我们再日常读取csv文件的时候经常

基于Python实现多语言朗读与单词选择测验

《基于Python实现多语言朗读与单词选择测验》在数字化教育日益普及的今天,开发一款能够支持多语言朗读和单词选择测验的程序,对于语言学习者来说无疑是一个巨大的福音,下面我们就来用Python实现一个这... 目录一、项目概述二、环境准备三、实现朗读功能四、实现单词选择测验五、创建图形用户界面六、运行程序七、

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、