当前位置: 首页 > news >正文

筛选图片,写JSON文件和复制

筛选图片,写JSON文件和复制

  • 筛选图片,写JSON文件
  • 筛选图片复制

筛选图片,写JSON文件

# coding: utf-8
from PIL import Image, ImageDraw, ImageFont
import os
import shutil
import cv2 as cv
import numpy as np
import jsondef zh_ch(string):return string.encode("gbk").decode('UTF-8', errors='ignore')def create_json(path):path_dict = {}path = path.split('\\')file_name = path[-1]return path_dict, file_namedef get_root(scr):scr = scr.split('\\')root_path = os.path.join(*scr[0:-1])file_name_1 = scr[-2]file_name_0 = scr[-1]return root_path, file_name_1, file_name_0def save_json(filename, dicts):filename = filename.replace(':', ':\\')with open(filename, 'w') as f:json_str = json.dumps(dicts)f.write(json_str)def image_add_text(img1, text, left, top, text_color, text_size):if isinstance(img1, np.ndarray):# 判断图片是否为ndarray格式,转为成PIL的格式的RGB图片image = Image.fromarray(cv.cvtColor(img1, cv.COLOR_BGR2RGB))draw = ImageDraw.Draw(image)# 创建一个可以在给定图像上绘图的对象font_style = ImageFont.truetype("font/simsun.ttc", text_size, encoding='utf-8')# 参数依次为 字体、字体大小、编码draw.text((left, top), text, text_color, font=font_style)# 参数依次为位置、文本、颜色、字体return cv.cvtColor(np.asarray(image), cv.COLOR_RGB2BGR)def redu(image, ratio):width = int(image.shape[1] * ratio)height = int(image.shape[0] * ratio)image = cv.resize(image, (width, height), interpolation=cv.INTER_AREA)return image
def bor_image(image, path, file_name):path = path.split('\\')if file_name[path[-1]] == 0:sen = '无缺陷'elif file_name[path[-1]] == 1:sen = '有缺陷'else:sen = '不确定'text = path[-1] + '     ' + sen +'\n上一张:w,下一张:s,退出:q\n无缺陷:Backspace,有缺陷:Enter,不确定:{'border_img = cv.copyMakeBorder(image, 70, 2, 2, 2, cv.BORDER_CONSTANT, value=[255, 255, 255])border_img = image_add_text(border_img, text, 0, 0, (255, 0, 0), 20)cv.imshow('image', border_img)def read_json(file_name):with open(file_name, 'rb') as f:data = json.load(f)return data
def press_key(path_lsit):# image = cv.imread(path, cv.IMREAD_GRAYSCALE)i = 0root_paths = []file_dict = {}while(0 <= i and i <= len(path_lsit)):print(path_lsit[i])if 'bmp' not in path_lsit[i]:i = i + 1continueroot_path, file_name_1, file_name_0 = get_root(path_lsit[i])print(root_path)if os.path.exists(os.path.join(root_path, 'kuaisu.json')):file_dict = read_json(os.path.join(root_path, 'kuaisu.json'))else:file_dict = {}image = cv.imdecode(np.fromfile(path_lsit[i], dtype=np.uint8), cv.IMREAD_COLOR)  # 输入图片路径,当路径中有中文时需要采用该语句image = cv.transpose(image)print(file_dict)# 缩小图片image = redu(image, 0.55)if file_name_0 not in file_dict:file_dict[file_name_0] = 0  # 无缺陷print(file_dict)bor_image(image, path_lsit[i], file_dict)key = cv.waitKey(0)if key == 115:i = i + 1save_json(os.path.join(root_path, 'kuaisu.json'), file_dict)continueif key == 119:i = i - 1save_json(os.path.join(root_path, 'kuaisu.json'), file_dict)continueif key == 13 or key == 8 or key == 91:#enter/baskspace/{if key == 13:file_dict[file_name_0] = 1#有缺陷bor_image(image, path_lsit[i], file_dict)print(file_dict)elif key == 8:file_dict[file_name_0] = 0#无缺陷bor_image(image, path_lsit[i], file_dict)print(file_dict)else:file_dict[file_name_0] = 2#不确定bor_image(image, path_lsit[i], file_dict)print(file_dict)save_json(os.path.join(root_path, 'kuaisu.json'), file_dict)key = cv.waitKey(0)if key == 115:i = i + 1save_json(os.path.join(root_path, 'kuaisu.json'), file_dict)continueelif key == 119:i = i - 1save_json(os.path.join(root_path, 'kuaisu.json'), file_dict)continueif key == 113:save_json(os.path.join(root_path, 'kuaisu.json'), file_dict[file_name_1])cv.destroyAllWindows()breakif __name__ == '__main__':image_root_path = "E:\正在标注"path_list = []scr_path = []# save_path_name = 'H:ImageStore\\ti'for root, dirs, files in os.walk(image_root_path):for file in files:path = os.path.join(root, file)if 'bmp' in path:path_list.append(path)press_key(path_list)

筛选图片复制

# coding: utf-8
from PIL import Image, ImageDraw, ImageFont
import os
import shutil
import cv2 as cv
import numpy as np
import json# 保留无缺陷的图片def zh_ch(string):return string.encode("gbk").decode('UTF-8', errors='ignore')def create_json(path):path_dict = {}path = path.split('\\')file_name = path[-1]return path_dict, file_namedef get_root(scr):scr = scr.split('\\')root_path = os.path.join(*scr[0:-1])file_name_1 = scr[-2]file_name_0 = scr[-1]return root_path, file_name_1, file_name_0def save_json(filename, dicts):filename = filename.replace(':', ':\\')with open(filename, 'w') as f:json_str = json.dumps(dicts)f.write(json_str)def image_add_text(img1, text, left, top, text_color, text_size):if isinstance(img1, np.ndarray):# 判断图片是否为ndarray格式,转为成PIL的格式的RGB图片image = Image.fromarray(cv.cvtColor(img1, cv.COLOR_BGR2RGB))draw = ImageDraw.Draw(image)# 创建一个可以在给定图像上绘图的对象font_style = ImageFont.truetype("font/simsun.ttc", text_size, encoding='utf-8')# 参数依次为 字体、字体大小、编码draw.text((left, top), text, text_color, font=font_style)# 参数依次为位置、文本、颜色、字体return cv.cvtColor(np.asarray(image), cv.COLOR_RGB2BGR)def redu(image, ratio):width = int(image.shape[1] * ratio)height = int(image.shape[0] * ratio)image = cv.resize(image, (width, height), interpolation=cv.INTER_AREA)return image
def bor_image(image, path, file_name):path = path.split('\\')if file_name[path[-1]] == 0:sen = '无缺陷'elif file_name[path[-1]] == 1:sen = '有缺陷'else:sen = '不确定'text = path[-1] + '     ' + sen +'\n上一张:w,下一张:s,退出:q\n有缺陷:Enter'border_img = cv.copyMakeBorder(image, 70, 2, 2, 2, cv.BORDER_CONSTANT, value=[255, 255, 255])border_img = image_add_text(border_img, text, 0, 0, (255, 0, 0), 20)cv.imshow('image', border_img)def read_json(file_name):with open(file_name, 'rb') as f:data = json.load(f)return data
def press_key(path_lsit,save_path):# image = cv.imread(path, cv.IMREAD_GRAYSCALE)i = 0root_paths = []file_dict = {}while(0 <= i and i <= len(path_lsit)):print(path_lsit[i])if 'bmp' not in path_lsit[i]:i = i + 1continueroot_path, file_name_1, file_name_0 = get_root(path_lsit[i])print(root_path)if os.path.exists(os.path.join(root_path, 'kuaisu.json')):file_dict = read_json(os.path.join(root_path, 'kuaisu.json'))else:file_dict = {}image = cv.imdecode(np.fromfile(path_lsit[i], dtype=np.uint8), cv.IMREAD_COLOR)  # 输入图片路径,当路径中有中文时需要采用该语句image = cv.transpose(image)print(file_dict)# 缩小图片image = redu(image, 0.55)if file_name_0 not in file_dict:file_dict[file_name_0] = 0  # 无缺陷print(file_dict)bor_image(image, path_lsit[i], file_dict)key = cv.waitKey(0)if key == 115:i = i + 1continueif key == 119:i = i - 1continueif key == 13 or key == 8 or key == 91:#enter/baskspace/{if key == 13:file_dict[file_name_0] = 1#有缺陷bor_image(image, path_lsit[i], file_dict)shutil.copy(path_lsit[i], save_path)  # shutil.copy函数放入原文件的路径文件全名  然后放入目标文件夹key = cv.waitKey(0)if key == 32:  # 空格#os.remove(save_path)my_list = path_lsit[i].split('\\')print(my_list[-1])os.remove(save_path+"\\"+my_list[-1])if key == 115:i = i + 1continueelif key == 119:i = i - 1continueif key == 113:cv.destroyAllWindows()breakif __name__ == '__main__':image_root_path = "D:\\Datasets\\defect2\\final9.4\\yes"path_list = []scr_path = []# save_path_name = 'H:ImageStore\\ti'for root, dirs, files in os.walk(image_root_path):for file in files:path = os.path.join(root, file)if 'bmp' in path:path_list.append(path)press_key(path_list,"E:\\Datasets\\defect2\\final9.4\\yes")

相关文章:

筛选图片,写JSON文件和复制

筛选图片&#xff0c;写JSON文件和复制 筛选图片&#xff0c;写JSON文件筛选图片复制 筛选图片&#xff0c;写JSON文件 # coding: utf-8 from PIL import Image, ImageDraw, ImageFont import os import shutil import cv2 as cv import numpy as np import jsondef zh_ch(str…...

C++并发编程:构建线程安全队列(第二部分:细粒度锁)

C++并发编程:构建线程安全队列(第二部分:细粒度锁) 1. 引言 在多线程环境下,为了保证数据的一致性和正确性,需要使用同步原语来对共享数据的访问进行互斥和同步。std::queue作为一种先进先出(FIFO)的数据结构,它本身并不是线程安全的,同时访问它可能导致数据竞争和不一致的问…...

浅述C++内存管理——new与malloc的不同

前言 C相对于其他语言有一个重要的特点就是对于内存的管理&#xff0c;相比于C语言&#xff0c;C提供了新的关键字new来代替malloc的功能&#xff0c;其中有何不同&#xff0c;请看下文。 一、内存的构成 在我们日常编程过程中最常接触到的就是以下四个分区 以下将分别给出例…...

语言基础篇11——函数、函数参数类型、装饰器、生成器

函数 基本结构 def func_name(value):print(f"Hello {value}")return 0func_name("World")函数参数 参数默认值和五种参数类型 https://docs.python.org/3/glossary.html#term-parameter 参数默认值 带默认值的参数必须在参数列表右边 def func_nam…...

linux jar包class热部署 工具 arthas安装及使用

在不改变类、方法 的前提下&#xff0c;在方法中对业务逻辑做处理 或 打日志等情况下使用。 建议线上日志调试时使用&#xff1a; arthas安装 1. 下载文件 arthas-packaging-3.7.1-bin.zip https://arthas.aliyun.com 2. 服务器安装arthas 2.1 服务器指定目录下创建目录 c…...

Android studio 调整jar包顺序

第一步&#xff1a;编译jar包&#xff0c;放入lib路径下&#xff1a;如&#xff1a; 第二步&#xff1a;app 目录下build.gradle 中添加 compileOnly files(libs/classes.jar) 第三步&#xff1a;project目录下build.gradle 中添加 allprojects {gradle.projectsEvaluated {t…...

用Qt写的机器视觉绘图工具

一个用QtGraphicsView写的机器视觉绘图工具&#xff0c;支持直线查找&#xff0c;圆拟合&#xff0c;卡尺工具&#xff0c;圆环查找等。底部GraphicsScene可以实时显示相机图像&#xff0c;工具获取图像后通过算法处理图像。 Project是基于Qt的例程项目qdraw改的。...

Spring Boot 打包,将依赖全部打进去

一、背景 spring boot 2.4.4 项目&#xff0c;打包&#xff0c;将依赖全部打进去 二、在pom.xml中引入插件 在项目的 pom.xml 文件中&#xff0c;添加 Maven 插件 spring-boot-maven-plugin&#xff0c;示例如下&#xff1a; <build><plugins><!-- ...其他插件…...

SpringCloud入门实战(十五)分布式事务框架Seata简介

&#x1f4dd; 学技术、更要掌握学习的方法&#xff0c;一起学习&#xff0c;让进步发生 &#x1f469;&#x1f3fb; 作者&#xff1a;一只IT攻城狮 &#xff0c;关注我&#xff0c;不迷路 。 &#x1f490;学习建议&#xff1a;1、养成习惯&#xff0c;学习java的任何一个技术…...

MySQL数据库 主从复制与读写分离

读写分离是什么 读写分离&#xff0c;基本的原理是让主数据库处理事务性增、改、删操作&#xff08;INSERT、UPDATE、DELETE&#xff09;&#xff0c;而从数据库处理SELECT查询操作。数据库复制被用来把事务性操作导致的变更同步到集群中的从数据库。 为什么要进行读写分离 因…...

Qt day2

目录 1.多态&#xff0c;虚函数&#xff0c;纯虚函数 1.多态性&#xff08;Polymorphism&#xff09;&#xff1a; 2.虚函数&#xff08;Virtual Function&#xff09;&#xff1a; 3.纯虚函数&#xff08;Pure Virtual Function&#xff09;&#xff1a; 将引用作为函数参…...

JavaScript - 好玩的打字动画

效果预览&#xff1a; &#x1f680;HTML版本 <!DOCTYPE html> <html> <head><title>打字动画示例</title><style>.typewriter {color: #000;overflow: hidden; /* 隐藏溢出的文本 */white-space: nowrap; /* 不换行 */border-right: .…...

rpm打包

文章目录 rpm打包 1. rpm打包步骤0&#xff09;准备工作&#xff1a;安装打包工具rpm-build和rpmdevtools&#xff08;1&#xff09;在线安装&#xff08;2&#xff09;离线安装 1&#xff09;创建初始化目录2&#xff09;准备打包内容3&#xff09;编写打包脚本 spec文件4&…...

匠心新品:大彩科技超薄7寸WIFI线控器发布,热泵、温控器、智能家电首选!

一、产品介绍 此次发布一款7寸高清全新外壳产品&#xff0c;让HMI人机界面家族再添一新成员。该产品相比其他外壳有以下5个大改动&#xff1a; 1 表面玻璃盖板使用2.5D立体结构&#xff1b; 2 液晶盖板采用一体黑设计&#xff0c;且液晶屏与触摸板是全贴合结构&#xff1b; …...

华为云云服务器评测|使用云耀云服务器L实例部署Portainer工具

华为云云服务器评测&#xff5c;使用云耀云服务器L实例部署Portainer工具 一、云耀云服务器L实例介绍1.1 云耀云服务器L实例简介1.2 云耀云服务器L实例特点1.3 云耀云服务器L实例使用场景 二、本次实践介绍2.1 本次实践简介2.2 Portainer简介 三、购买云耀云服务器L实例3.1 登录…...

C++并发编程:构建线程安全队列(第一部分:粗粒度锁)

C并发编程&#xff1a;构建线程安全队列&#xff08;第一部分&#xff1a;粗粒度锁&#xff09; 引言 在多线程编程中&#xff0c;线程之间的数据共享和通信是一个非常重要的问题。在这篇博客中&#xff0c;我们将讨论如何用C实现一个基础但非常实用的线程安全队列。这个队列…...

C++设计模式-更新中

单例模式 这个类实现了单例模式。单例模式是一种设计模式&#xff0c;旨在确保一个类只有一个实例&#xff0c;并提供一个全局访问点来获取该实例。 在 ConnectionManager 类中&#xff0c;它通过以下方式实现了单例模式&#xff1a; 构造函数 ConnectionManager() 被声明为…...

Hydra工具的使用

目录 Hydra初识 Hydra使用 hydra破解mysql 前言 不固定用户名密码爆破 hydra破解ssh 以用户名为密码登录 hydra破解rdp 将爆破密码的结果输出到文件中 Hydra初识 前言&#xff1a; hydra是一款开源的暴力破解工具&#xff0c;支持多种服务破解原理&#xff1a;使用户…...

Pytorch学习:卷积神经网络—nn.Conv2d、nn.MaxPool2d、nn.ReLU、nn.Linear和nn.Dropout

文章目录 1. torch.nn.Conv2d2. torch.nn.MaxPool2d3. torch.nn.ReLU4. torch.nn.Linear5. torch.nn.Dropout 卷积神经网络详解&#xff1a;csdn链接 其中包括对卷积操作中卷积核的计算、填充、步幅以及最大值池化的操作。 1. torch.nn.Conv2d 对由多个输入平面组成的输入信号…...

水果库存系统(SSM+Thymeleaf版)

不为失败找理由&#xff0c;只为成功找方法。所有的不甘&#xff0c;因为还心存梦想&#xff0c;所以在你放弃之前&#xff0c;好好拼一把&#xff0c;只怕心老&#xff0c;不怕路长。 文章目录 一、前言二、系统架构与需求分析1、技术栈1.1 后端1.2 前端 2、需求分析 三、设计…...

label-studio的使用教程(导入本地路径)

文章目录 1. 准备环境2. 脚本启动2.1 Windows2.2 Linux 3. 安装label-studio机器学习后端3.1 pip安装(推荐)3.2 GitHub仓库安装 4. 后端配置4.1 yolo环境4.2 引入后端模型4.3 修改脚本4.4 启动后端 5. 标注工程5.1 创建工程5.2 配置图片路径5.3 配置工程类型标签5.4 配置模型5.…...

React Native在HarmonyOS 5.0阅读类应用开发中的实践

一、技术选型背景 随着HarmonyOS 5.0对Web兼容层的增强&#xff0c;React Native作为跨平台框架可通过重新编译ArkTS组件实现85%以上的代码复用率。阅读类应用具有UI复杂度低、数据流清晰的特点。 二、核心实现方案 1. 环境配置 &#xff08;1&#xff09;使用React Native…...

数据链路层的主要功能是什么

数据链路层&#xff08;OSI模型第2层&#xff09;的核心功能是在相邻网络节点&#xff08;如交换机、主机&#xff09;间提供可靠的数据帧传输服务&#xff0c;主要职责包括&#xff1a; &#x1f511; 核心功能详解&#xff1a; 帧封装与解封装 封装&#xff1a; 将网络层下发…...

CRMEB 框架中 PHP 上传扩展开发:涵盖本地上传及阿里云 OSS、腾讯云 COS、七牛云

目前已有本地上传、阿里云OSS上传、腾讯云COS上传、七牛云上传扩展 扩展入口文件 文件目录 crmeb\services\upload\Upload.php namespace crmeb\services\upload;use crmeb\basic\BaseManager; use think\facade\Config;/*** Class Upload* package crmeb\services\upload* …...

高防服务器能够抵御哪些网络攻击呢?

高防服务器作为一种有着高度防御能力的服务器&#xff0c;可以帮助网站应对分布式拒绝服务攻击&#xff0c;有效识别和清理一些恶意的网络流量&#xff0c;为用户提供安全且稳定的网络环境&#xff0c;那么&#xff0c;高防服务器一般都可以抵御哪些网络攻击呢&#xff1f;下面…...

Swagger和OpenApi的前世今生

Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章&#xff0c;二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑&#xff1a; &#x1f504; 一、起源与初创期&#xff1a;Swagger的诞生&#xff08;2010-2014&#xff09; 核心…...

Mac下Android Studio扫描根目录卡死问题记录

环境信息 操作系统: macOS 15.5 (Apple M2芯片)Android Studio版本: Meerkat Feature Drop | 2024.3.2 Patch 1 (Build #AI-243.26053.27.2432.13536105, 2025年5月22日构建) 问题现象 在项目开发过程中&#xff0c;提示一个依赖外部头文件的cpp源文件需要同步&#xff0c;点…...

安宝特方案丨船舶智造的“AR+AI+作业标准化管理解决方案”(装配)

船舶制造装配管理现状&#xff1a;装配工作依赖人工经验&#xff0c;装配工人凭借长期实践积累的操作技巧完成零部件组装。企业通常制定了装配作业指导书&#xff0c;但在实际执行中&#xff0c;工人对指导书的理解和遵循程度参差不齐。 船舶装配过程中的挑战与需求 挑战 (1…...

JS设计模式(4):观察者模式

JS设计模式(4):观察者模式 一、引入 在开发中&#xff0c;我们经常会遇到这样的场景&#xff1a;一个对象的状态变化需要自动通知其他对象&#xff0c;比如&#xff1a; 电商平台中&#xff0c;商品库存变化时需要通知所有订阅该商品的用户&#xff1b;新闻网站中&#xff0…...

Linux nano命令的基本使用

参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时&#xff0c;显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...