用python实现识别框选图片字体部分,并分割成单独图片
CSDN问答频道为您的问题找到合适的答案,帮助用户获得可信赖的优质解答
原问题来自于CSDN问答频道,该问题来源:https://ask.csdn.net/questions/7415845
问题描述:
如何通过代码可以识别框选字体部分(矩形框),并分割成单独图片
解决方案——来自答主@桔子code
用python实现,需要安装opencv、numpy模块:切割准确率95%以上, 效果图:
具体代码如下:
#juzicode.com/vx:桔子code
import os,sys,time,cv2
import numpy as npdbg_is_show = False
def show_img(win_name,img,wait_time=0,img_ratio=0.15,is_show=True):if is_show is not True:return rows = img.shape[0]cols = img.shape[1]cv2.namedWindow(win_name, cv2.WINDOW_NORMAL )#cv2.WINDOW_AUTOSIZE)cv2.resizeWindow(win_name,(int(cols*img_ratio),int(rows*img_ratio)))cv2.imshow(win_name,img)cv2.waitKey(wait_time)if not os.path.exists('out'):os.mkdir('out')print('juzicode.com/vx:桔子code')
print(cv2.__version__)
img_src = cv2.imread('src.jpg')
print(img_src.shape)show_img('img_src',img_src,is_show=dbg_is_show)#获取灰度图
img_b, img_g, img_r = cv2.split(img_src)
show_img('img_r',img_r,is_show=dbg_is_show)img_gray = cv2.bitwise_not(img_r)
img_gray= cv2.medianBlur(img_gray,5)#二值化
thresh_bin,img_bin= cv2.threshold(img_gray,127,255,cv2.THRESH_BINARY)
show_img('img_bin',img_bin,is_show=dbg_is_show)kernel = cv2.getStructuringElement(cv2.MORPH_RECT,(3, 3))
img_eroded = cv2.erode(img_bin,kernel)
show_img('img_eroded',img_eroded) kernel = cv2.getStructuringElement(cv2.MORPH_RECT,(29, 29))
img_dilated = cv2.dilate(img_eroded,kernel)
show_img('img_dilated',img_dilated)res = cv2.findContours(img_dilated,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
contours=res[1]
print ('len(contours):',len(contours))for i in range(0,len(contours)): x, y, w, h = cv2.boundingRect(contours[i])print(i,len(contours[i]))if len(contours[i])<80:continuecv2.rectangle(img_src, (x,y), (x+w,y+h), (255,0,0), 10)newimage=img_src[y:y+h,x:x+w]cv2.imwrite( 'out\\'+str(i)+".jpg",newimage)show_img("img_dilated_with_contour", img_src)
有问题欢迎到CSDN问答频道提问,欢迎各位到问答频道回答,您的回答是对题主最大的帮助!
用python实现识别框选图片字体部分,并分割成单独图片相关推荐
- Java操作长方形图片补全不失真成正方形图片
Java操作长方形图片补全不失真成正方形图片 BufferedImage image = ImageIO.read(new FileInputStream(new File("C:\\Use ...
- python PIL图像处理-框选
框选图中位置 代码 from PIL import Image,ImageDraw,ImageFont,ImageFilter import random#---------------------- ...
- 用 Python 人脸识别,选抖音上好看的小姐姐
点击"开发者技术前线",选择"星标"? 在看|星标|留言, 真爱 1 目 标 场 景 相信大家平时刷抖音短视频的时候,看到颜值高的小姐姐,都有随手点赞关注的习 ...
- java 将一张图片切割成n个小图片,任意切割一张图片成新图片
根据图片的选中左上角度坐标和宽高来截取生成新的图片.测试通过,并已在项目中运用.但是不能切割动态的gif图片.有点遗憾,待优化. ---注:main方法调试代码记得修改图片路径 package com ...
- python人脸识别框很小_人脸识别:从传统方法到深度学习
人脸识别:从传统方法到深度学习 这开始于上世纪七十年代,人脸识别成为了计算机视觉领域和生物识别领域最具有研究型的话题之一.传统方法依赖于手工制作模型特征,通过深度神经网络训练大量的数据集的方法也在最近 ...
- 图像处理+帧差法实现对车辆的识别框选
每一帧一个动作,连接起形成一个动画 帧差法:对每一帧进行分析,对帧内分为动态和静态物体,前一帧与后一帧相对移动的物体识别出. opencv中有专门对帧差的函数,以识别运动中的物体 原视频图像: 函数设 ...
- python 阴阳师 识别图像_Python爬取阴阳师式神全图鉴图片
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理. 基本环境配置 python 3.6 pycharm requests 目标网页 经过一些系列 ...
- 图片上传并转成灰白图片
这是以前做webim时写的上传用户头像时要生成离线状态的图片,即黑白图片的代码 函数代码如下: Code public void MakeSmallImg(string fileName, strin ...
- Python爬虫识别中文字符和标点符号
Python爬虫识别中文字符和标点符号,并且保存成txt文档 import requestshref_list = final_df["隐私政策"].values names = ...
最新文章
- python 制作自定义包并安装
- Probabilistic Principal Component Analysis
- VTK:可视化算法之DataSetSurface
- 聊城大学计算机学院答辩,数学与信息工程系成功举办精品课程答辩会
- Centos 能ping通域名和公网ip但是网站不能够打开,服务器拒绝了请求。打开80端口解决。...
- FreeRTOS操作系统,在按键中断函数中恢复被挂起的任务,程序卡死的原因和解决办法...
- pitr 原理_PostgreSQL热备原理研究及流复制运用
- iOS学习之基本概念
- Java游戏触屏处理,非触屏java游戏转换为触屏游戏工具使用方法
- QT:不停的提示“文件已改变”
- _event_phase_team
- mysql用户创建、授权
- 罗技鼠标 903 底部按键是干嘛的,板载模式
- 信道估计算法matlab代码汇总
- 完美融入云原生的无代码平台 iVX编辑器介绍
- 字谜 大小写重复全排列问题
- 计算机考试从哪里如何出题,计算机基础考试系统出题-第4章 excel.xls
- PowerPoint基础操作-PowerPoint学习记录-8.1/2/3/4
- 【python学习】-字典学习(访问字典所有键与值、修改与更新字典、删除字典)
- 刘强东怼天猫,是在陈述事实还是另有深意?