【无标题】提取图片并进行灰度拉伸

该代码使用OpenCV库将指定文件夹下所有RGB图像转换为灰度图像。它首先读取目录结构,然后对每个子目录中的图片进行灰度处理,如果图片已存在则跳过。处理过程包括将图片转换为一维数组,找到最小和最大像素值,然后计算新的灰度值并保存结果。
import cv2
import numpy as np
import os


def grey_scale(image):
    img_gray = cv2.cvtColor(image, cv2.COLOR_RGB2GRAY)

    rows, cols = img_gray.shape
    flat_gray = img_gray.reshape((cols * rows,)).tolist()
    A = min(flat_gray)
    B = max(flat_gray)
    if A==B:
        return 'Wrong'
    output = np.uint8(255 / (B - A) * (img_gray - A) + 0.5)
    return output

if __name__=='__main__':
    root='D:\BaiduNetdiskDownload\\necvset\\necv'
    save_root='D:\BaiduNetdiskDownload\\necvset\\result_wv'
    folders=os.listdir(root)
    folders.sort()
    for folder in folders:
        files=os.listdir(f'{root}\\{folder}')
        files.sort()
        for file in files:
            imgs=os.listdir(f'{root}\\{folder}\\{file}')
            imgs.sort()
            save=f'{save_root}\\{folder}\\{file}'
            if not os.path.exists(save):
                os.makedirs(save)
            for img in imgs:
                if 'WV' in img:
                    if os.path.exists(f'{save}\\{img}'):
                        continue
                    print(f'{root}\\{folder}\\{file}\\{img}')
                    src = cv2.imread(f'{root}\\{folder}\\{file}\\{img}')
                    result = grey_scale(src)
                    if result=='Wrong':
                        continue
                    cv2.imwrite(f'{save}\\{img}',result)

图片地址D:\BaiduNetdiskDownload\necvset\necv\2020\20200101

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值