IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发工具 -> python读图片生成ROI并保存 -> 正文阅读

[开发工具]python读图片生成ROI并保存

先识别数字,后用数字命名,再保存

import cv2
import numpy as np
import matplotlib.pyplot as plt
import pytesseract
import os
from os.path import join

pytesseract.pytesseract.tesseract_cmd = r"C:\Program Files (x86)\Tesseract-OCR\tesseract.exe"

config='--psm 6 --oem 1 -c tessedit_char_whitelist=0123456789'

path = r"D:\BUFFER\Pycharm\OpencvLearn\images\OCR"
determination = "images/ROI_Images"

def rotate_bound(image, angle):
    # grab the dimensions of the image and then determine the
    # center
    (h, w) = image.shape[:2]
    (cX, cY) = (w // 2, h // 2)

    # grab the rotation matrix (applying the negative of the
    # angle to rotate clockwise), then grab the sine and cosine
    # (i.e., the rotation components of the matrix)
    M = cv2.getRotationMatrix2D((cX, cY), -angle, 1.0)
    cos = np.abs(M[0, 0])
    sin = np.abs(M[0, 1])

    # compute the new bounding dimensions of the image
    nW = int((h * sin) + (w * cos))
    nH = int((h * cos) + (w * sin))

    # adjust the rotation matrix to take into account translation
    M[0, 2] += (nW / 2) - cX
    M[1, 2] += (nH / 2) - cY

    # perform the actual rotation and return the image
    return cv2.warpAffine(image, M, (nW, nH))


for filename in os.listdir(path):  # listdir的参数是文件夹的路径
    filenames = path + '\\' + filename
    # print(filenames)
    img_orig = cv2.imread(filenames, 1)
    # print(filenames)

    image_RGB = cv2.cvtColor(img_orig, cv2.COLOR_BGR2RGB)
    # cv2.rectangle(image_RGB, (1150,820),(1400,950),(0,0,255),1)
    ROI = image_RGB[820:950, 1165:1380]
    img = ROI.copy()
    # print(pytesseract.image_to_boxes(ROI))

    # cv2.imshow("roi", ROI)
    # cv2.waitKey(0)

    kernel = np.ones((5,5), np.uint8)
    open_img = cv2.morphologyEx(img, cv2.MORPH_OPEN, kernel)

    # cv2.imshow("images", open_img)
    left_thred = 240
    gray_img = cv2.cvtColor(open_img,cv2.COLOR_RGB2GRAY)
    ret, thresh1 = cv2.threshold(gray_img, left_thred, 255, cv2.THRESH_BINARY)

    thresh1[0:20, 0:100] = 255
    thresh1[105:129, 0:210] = 255
    blur = cv2.blur(thresh1, (3,3))
    # cv2.imshow("thresh",thresh1)
    # cv2.waitKey(0)
    img_strings = pytesseract.image_to_string(blur)

    img_rotate = rotate_bound(img, -5)

    ROI = img_rotate[28:113, 15:220]

    strings = img_strings[:6]
    if len(strings) == 6:
        fileName = strings + ".jpg"
        # cv2.imwrite('images/ROI_Images/' + fileName,ROI)
        cv2.imwrite('images/rcnnROI/'+ fileName,ROI)

    print(img_strings[:6])

  开发工具 最新文章
Postman接口测试之Mock快速入门
ASCII码空格替换查表_最全ASCII码对照表0-2
如何使用 ssh 建立 socks 代理
Typora配合PicGo阿里云图床配置
SoapUI、Jmeter、Postman三种接口测试工具的
github用相对路径显示图片_GitHub 中 readm
Windows编译g2o及其g2o viewer
解决jupyter notebook无法连接/ jupyter连接
Git恢复到之前版本
VScode常用快捷键
上一篇文章      下一篇文章      查看所有文章
加:2021-11-26 09:03:29  更:2021-11-26 09:05:41 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/23 17:25:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码