ddddocr

ddddocr

多功能验证码识别库 支持OCR与目标检测

ddddocr是一个开源的验证码识别库,支持基础OCR、目标检测和滑块识别等多种功能。该项目采用深度学习技术,无需针对特定验证码训练,具有通用性强的特点。ddddocr支持Windows、Linux和MacOS等主流操作系统,提供Python接口便于集成。项目设计注重简化配置和使用流程,为开发者提供了一个高效的验证码识别工具。

DdddOcr验证码识别OCR目标检测滑块检测Github开源项目

DdddOcr 带带弟弟OCR通用验证码离线本地识别SDK免费开源版

DdddOcr 是由本作者kerlomz共同合作完成的项目。通过大批量生成随机数据后进行深度网络训练,该库并非针对任何特定验证码厂商而制作。使用效果完全靠玄学,可能可以识别,也可能无法识别。

DdddOcr 秉承最简依赖的理念,尽量减少用户的配置和使用成本,希望给每一位测试者带来舒适的体验。

项目地址:点击这里

自营GPT聚合平台:点击这里

<!-- 项目徽章 -->

[![贡献者][contributors-shield]][contributors-url] [![分支][forks-shield]][forks-url] [![星标][stars-shield]][stars-url] [![问题][issues-shield]][issues-url] [![MIT 许可证][license-shield]][license-url]

<!-- 项目 LOGO --> <br /> <p align="center"> <a href="https://github.com/shaojintian/Best_README_template/"> <img src="https://cdn.wenanzhe.com/img/logo.png!/crop/700x500a400a500" alt="Logo"> </a> <p align="center"> 一个易于使用的通用验证码识别Python库 <br /> <a href="https://github.com/shaojintian/Best_README_template"><strong>探索本项目的文档 »</strong></a> <br /> <br /> · <a href="https://github.com/sml2h3/ddddocr/issues">报告Bug</a> · <a href="https://github.com/sml2h3/ddddocr-fastapi">一键API服务</a> · <a href="https://github.com/sml2h3/ddddocr/issues">提出新特性</a> </p> </p>

目录

赞助合作商

赞助合作商推荐理由
YesCaptchaYesCaptcha谷歌reCaptcha验证码 / hCaptcha验证码 / funCaptcha验证码商业级识别接口 点击这里 直达VIP4
超级鹰超级鹰全球领先的智能图片分类及识别商家,安全、准确、高效、稳定、开放,强大的技术及校验团队,支持大并发。7*24小时作业进度管理
MaleniaMaleniaMalenia企业级代理IP网关平台/代理IP分销软件
雨云VPS注册首月5折浙江节点低价大带宽,100M每月30元

上手指南

环境支持
系统CPUGPU最大支持Python版本备注
Windows 64位3.12部分版本Windows需要安装<a href="https://www.ghxi.com/yxkhj.html">VC运行库</a>
Windows 32位××-
Linux 64 / ARM643.12
Linux 32××-
macOS X643.12M1/M2/M3...芯片参考<a href="https://github.com/sml2h3/ddddocr/issues/67">#67</a>
安装步骤

i. 从PyPI安装

pip install ddddocr

ii. 从源码安装

git clone https://github.com/sml2h3/ddddocr.git cd ddddocr python setup.py

请勿直接在ddddocr项目的根目录内直接import ddddocr,请确保你的开发项目目录名称不为ddddocr,这是基础常识。

文件目录说明

例如:

ddddocr 
├── MANIFEST.in
├── LICENSE
├── README.md
├── /ddddocr/
│  │── __init__.py            主代码库文件
│  │── common.onnx            新ocr模型
│  │── common_det.onnx        目标检测模型
│  │── common_old.onnx        老ocr模型
│  │── logo.png
│  │── README.md
│  │── requirements.txt
├── logo.png
└── setup.py

iii. 一键启动 <a href="https://github.com/sml2h3/ddddocr-fastapi">一键API服务</a>

项目底层支持

本项目基于dddd_trainer训练所得,训练底层框架为PyTorch,ddddocr推理底层依赖于onnxruntime,因此本项目的最大兼容性与Python版本支持主要取决于onnxruntime

使用文档

i. 基础OCR识别能力

主要用于识别单行文字,即文字部分占据图片的主体部分,例如常见的英数验证码等。本项目可以识别中文、英文(随机大小写或通过设置结果范围限定大小写)、数字以及部分特殊字符。

# example.py import ddddocr ocr = ddddocr.DdddOcr() image = open("example.jpg", "rb").read() result = ocr.classification(image) print(result)

本库内置两套OCR模型,默认情况下不会自动切换,需要在初始化ddddocr时通过参数进行切换

# example.py import ddddocr ocr = ddddocr.DdddOcr(beta=True) # 切换为第二套OCR模型 image = open("example.jpg", "rb").read() result = ocr.classification(image) print(result)

提示 对于部分透明黑色PNG格式图片的识别支持:classification 方法使用 png_fix 参数,默认为False

ocr.classification(image, png_fix=True)

注意

之前发现很多人喜欢在每次OCR识别时都重新初始化ddddocr,即每次都执行ocr = ddddocr.DdddOcr(),这是错误的。通常来说只需要初始化一次即可,因为每次初始化和初始化后的第一次识别速度都非常慢。

参考例图 包括但不限于以下图片

[图片1-12]

ii. 目标检测能力

主要用于快速检测出图像中可能的目标主体位置。由于被检测出的目标不一定为文字,所以本功能仅提供目标的边界框位置。(在目标检测中,我们通常使用边界框(bounding box,缩写为bbox)来描述目标位置。边界框是一个矩形框,可以由矩形左上角的x和y坐标与右下角的x和y坐标确定)

如果在使用过程中不需要调用OCR功能,可以在初始化时通过传入参数ocr=False来关闭OCR功能。开启目标检测需要传入参数det=True

import ddddocr import cv2 det = ddddocr.DdddOcr(det=True) with open("test.jpg", 'rb') as f: image = f.read() bboxes = det.detection(image) print(bboxes) im = cv2.imread("test.jpg") for bbox in bboxes: x1, y1, x2, y2 = bbox im = cv2.rectangle(im, (x1, y1), (x2, y2), color=(0, 0, 255), thickness=2) cv2.imwrite("result.jpg", im)

参考示例图

包括但不限于以下图片

[图片13-19]

Ⅲ. 滑块检测

本项目的滑块检测功能并非通过AI识别实现,而是使用OpenCV内置算法实现。这可能对于截图用户不太友好。如果在使用过程中不需要调用OCR功能或目标检测功能,可以在初始化时通过传入参数ocr=False来关闭OCR功能,或det=False来关闭目标检测功能。

本功能内置两套算法实现,适用于两种不同情况,具体请参考以下说明:

a.算法1

算法1的原理是通过滑块图像的边缘在背景图中计算找到相对应的凹槽位置。可以分别获取滑块图和背景图,滑块图为透明背景图。

滑块图

[图片20]

背景图

[图片21]

det = ddddocr.DdddOcr(det=False, ocr=False) with open('target.png', 'rb') as f: target_bytes = f.read() with open('background.png', 'rb') as f: background_bytes = f.read() res = det.slide_match(target_bytes, background_bytes) print(res)

由于滑块图可能存在透明边框的问题,导致计算结果不一定准确,需要自行估算滑块图透明边框的宽度用于修正得出的边界框。

提示:如果滑块没有过多背景部分,则可以添加simple_target参数,通常为jpg或bmp格式的图片

slide = ddddocr.DdddOcr(det=False, ocr=False) with open('target.jpg', 'rb') as f: target_bytes = f.read() with open('background.jpg', 'rb') as f: background_bytes = f.read() res = slide.slide_match(target_bytes, background_bytes, simple_target=True) print(res)

b.算法2

算法2是通过比较两张图的不同之处来判断滑块目标凹槽的位置。

参考图a,带有目标凹槽阴影的全图

[图片22]

参考图b,全图

[图片23]

slide = ddddocr.DdddOcr(det=False, ocr=False) with open('bg.jpg', 'rb') as f: target_bytes = f.read() with open('fullpage.jpg', 'rb') as f: background_bytes = f.read() img = cv2.imread("bg.jpg") res = slide.slide_comparison(target_bytes, background_bytes) print(res)
Ⅳ. OCR概率输出

为了提供更灵活的OCR结果控制和范围限定,该项目支持对OCR结果进行范围限定。

可以通过在调用classification方法时传递参数probability=True,此时classification方法将返回完整字符表的概率。 也可以通过set_ranges方法设置输出字符范围来限定返回的结果。

Ⅰ. set_ranges方法限定返回字符

本方法接受1个参数,如果输入为int类型则为内置的字符集限制,string类型则为自定义的字符集。

如果为int类型,请参考下表:

参数值含义
0纯数字0-9
1纯小写英文字母a-z
2纯大写英文字母A-Z
3小写英文字母a-z + 大写英文字母A-Z
4小写英文字母a-z + 数字0-9
5大写英文字母A-Z + 数字0-9
6小写英文字母a-z + 大写英文字母A-Z + 数字0-9
7默认字符库 - 小写英文字母a-z - 大写英文字母A-Z - 数字0-9

如果为string类型,请传入一段不包含空格的文本,其中的每个字符均为一个待选词。 例如:"0123456789+-x/=""

import ddddocr ocr = ddddocr.DdddOcr() image = open("test.jpg", "rb").read() ocr.set_ranges("0123456789+-x/=") result = ocr.classification(image, probability=True) s = "" for i in result['probability']: s += result['charsets'][i.index(max(i))] print(s)
Ⅴ. 自定义OCR训练模型导入

本项目支持导入来自 dddd_trainer 进行自定义训练后的模型,参考导入代码如下:

import ddddocr ocr = ddddocr.DdddOcr(det=False, ocr=False, import_onnx_path="myproject_0.984375_139_13000_2022-02-26-15-34-13.onnx", charsets_path="charsets.json") with open('test.jpg', 'rb') as f: image_bytes = f.read() res = ocr.classification(image_bytes) print(res)

版本控制

该项目使用Git进行版本管理。您可以在仓库中查看当前可用版本。

相关推荐文章或项目

带带弟弟OCR,纯VBA本地获取网络验证码整体解决方案

ddddocr rust 版本

captcha-killer的修改版

通过ddddocr训练字母数字验证码模型并识别部署调用

...

欢迎更多优秀案例或教程进行投稿,可直接新建issue,标题以【投稿】开头,附上公开教程站点链接。我会根据文章内容选择相对不重复或者有重点内容的进行readme展示,感谢各位朋友~

作者

sml2h3@gamil.com

<img src="https://cdn.wenanzhe.com/img/mmqrcode1640418911274.png!/scale/50" alt="wechat" width="150">

好友数过多不一定通过,有问题可以在issue进行交流

版权说明

该项目签署了MIT 授权许可,详情请参阅 LICENSE

捐赠 (如果项目对您有帮助,可以选择捐赠一些费用用于ddddocr的后续版本维护,本项目长期维护)

<img src="https://yellow-cdn.veclightyear.com/835a84d5/5a1379f2-361f-4f4a-8002-5e9773f5f80b.jpg" alt="captcha" width="150"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/4ba219b9-35b9-4981-ae43-51108fc9767e.jpg" alt="captcha" width="150">

Star 历史

Star History Chart

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多