PPOCRLabel标注的txt格式如何转换成labelme能修改的json格式

 更新时间:2023年03月25日 10:15:04   作者:雪地(>^ω^<)  
这篇文章主要介绍了PPOCRLabel标注的txt格式如何转换成labelme能修改的json格式问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

PPOCRLabel标注的txt格式转换成labelme能修改的json格式

PPOCR是个好东西

默认的训练文件是用自带的PPOCRLabel标注的,有时候需要用labelme来修改一些东西,比如后期用到的字段提取,就需要加一个参数,PPOCRLabel就没法做了,只能转成labelme,并利用group_id这个参数来赋值。

所以写了下面这个脚本

Label.txt每一行对应一个图片标注,该脚本作用是将PPOCRLabel的标注文件Label.txt转换为一个一个的json文件

并存储至json1目录下:

# -*- coding:utf-8 -*-
# 开发人员 : csu·攀-_-||
# 开发时间 : 2021/9/7 0007 10:30
# 文件名称 : pplable2json.py
# 开发工具 : PyCharm
# 功能描述 : PPOCRLabel标注的txt格式转换成labelme能修改的json格式

import os
import cv2
import json
import base64

#转base64
def image_to_base64(image_np):
    image = cv2.imencode('.jpg', image_np)[1]
    image_code = str(base64.b64encode(image))[2:-1]
    return image_code

def pp2json(path,savepath):
    with open(os.path.join(path,'Label.txt'),'r',encoding='utf-8') as f:
        for line in f.readlines():
            line = line.strip('\n')  # 去掉列表中每一个元素的换行符
            imgname = line.split('\t')[0].split('/')[1]
            img = cv2.imread(os.path.join(path,imgname))
            H,W,C = img.shape
            items = json.loads(line.split('\t')[1])
            item_shapes = []
            for item in items:
                item_shapes.append({
                    "label":item['transcription'],
                    "points":item['points'],
                    "group_id": 0,
                    "shape_type": "polygon",
                    "flags": {}
                })
            new_dict = {
                "version": "4.5.9",
                "flags": {},
                "shapes": item_shapes,
                "imagePath": imgname,
                "imageData": image_to_base64(img),
                "imageHeight": H,
                "imageWidth": W
            }
            with open(os.path.join(savepath,imgname.split('.')[0] + '.json'), "w",encoding='utf-8') as fw:
                print(imgname,' succeed!')
                json.dump(new_dict, fw)


if __name__ == '__main__':
    path = r'E:\Projects\OCR-release-2.1\tools\infer\imgs\train_data'
    savepath = r'json1'
    pp2json(path,savepath)

在这里插入图片描述

PPOCRLabel标注的Label.txt文件,所有的图片标注都在一个txt里头,一个图片一行,文件名和标注内容之间用制表符’\t’隔开。

在这里插入图片描述

labelme标注的json文件格式

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于Pycharm配置翻译插件Translation报错更新TTK失败不能使用的问题

    关于Pycharm配置翻译插件Translation报错更新TTK失败不能使用的问题

    这篇文章主要介绍了关于Pycharm配置翻译插件Translation报错更新TTK失败不能使用的问题,本文通过图文并茂的形式给大家分享解决方案,需要的朋友可以参考下
    2022-04-04
  • 基于Python实现绘制简单动图的示例详解

    基于Python实现绘制简单动图的示例详解

    动画是一种高效的可视化工具,能够提升用户的吸引力和视觉体验,有助于以富有意义的方式呈现数据可视化,本文的主要介绍在Python中两种简单制作动图的方法,需要的可以了解下
    2023-10-10
  • python3.x zip用法小结

    python3.x zip用法小结

    这篇文章主要介绍了python3.x zip用法详解,通过一个简单例子给大家详细讲解zip使用,结合示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • Python arrow模块使用方法

    Python arrow模块使用方法

    Arrow 是用于处理日期和时间的 Python 模块。 与内置的日期和时间工具相比,它使创建,操作,格式化和转换日期,时间和时间戳变得更加容易
    2022-10-10
  • Python二叉树的遍历操作示例【前序遍历,中序遍历,后序遍历,层序遍历】

    Python二叉树的遍历操作示例【前序遍历,中序遍历,后序遍历,层序遍历】

    这篇文章主要介绍了Python二叉树的遍历操作,结合实例形式分析了Python针对二叉树的前序遍历,中序遍历,后序遍历,层序遍历等相关操作实现技巧,需要的朋友可以参考下
    2018-12-12
  • pytorch 中transforms的使用详解

    pytorch 中transforms的使用详解

    本文主要介绍了pytorch中transforms的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • Python安装Gradio和常见安装问题解决办法

    Python安装Gradio和常见安装问题解决办法

    Gradio是一款便捷的Python库,专门用于创建机器学习模型的Web应用,安装通常简单,但偶尔会遇到依赖问题或环境配置错误,这篇文章主要介绍了Python安装Gradio和常见安装问题解决办法,需要的朋友可以参考下
    2024-10-10
  • Pycharm学习教程(4) Python解释器的相关配置

    Pycharm学习教程(4) Python解释器的相关配置

    这篇文章主要为大家详细介绍了最全的Pycharm学习教程第四篇,Python解释器配置,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • 使用Python的Zato发送AMQP消息的教程

    使用Python的Zato发送AMQP消息的教程

    这篇文章主要介绍了使用Python的Zato发送AMQP消息的教程,主要是基于一些Zato的图形化界面进行操作,需要的朋友可以参考下
    2015-04-04
  • 运行Python编写的程序方法实例

    运行Python编写的程序方法实例

    在本篇文章里小编给大家整理了关于运行Python编写的程序方法实例内容,有兴趣的朋友们可以学习下。
    2020-10-10

最新评论