用python按照图像灰度值统计并筛选图片的操作(PIL,shutil,os)


Posted in Python onJune 04, 2020

我就废话不多说了,大家还是直接看代码吧!

import PIL.Image
import numpy
import os
import shutil
def sum_right(path):
 img = PIL.Image.open(path)
 array = numpy.array(img)
 num = array.sum(axis=0)
 print(type(num))
 res_left = 0
 res_right = 0
 for i in range(256,512):
  res_right += num[i]
 print(res_right)

if __name__ == '__main__':
 dir2 = r"C:\Users\Howsome\Desktop\tst"
 dir1 = r"C:\Users\Howsome\Desktop\AB"
 names = os.listdir(dir1)
 n = len(names)
 print("文件数量",n)
 res = 0
 average_5 = 25565356
 average_25 = 26409377
 average_5_right = 10006019
 #average_tmp = (average_25+average_5)//2
 count = 0
 #show(os.path.join(dir1, "uni4F6C.png"))
 for i in range(n):
  #取图片
  img = PIL.Image.open(os.path.join(dir1,names[i]))
  file = os.path.join(dir1,names[i])
  rmfile = os.path.join(dir2,names[i])
  array = numpy.array(img)
  num = array.sum(axis=0)
  res_right = 0
  for i in range(256, 512):
   res_right += num[i]
  average_5_right += res_right/n

  if res_right > average_5_right:
    shutil.copyfile(file, rmfile)
    os.remove(file)
    count += 1
 print(average_5_right)
 print(count)

补充知识:python遍历灰度图像像素方法总结

啥也不说了,看代码吧!

import numpy as np
import matplotlib.pyplot as plt
import cv2
import time

img = cv2.imread('lena.jpg',0)

# 以遍历每个像素取反为例

# 方法1
t1 = time.time()
img1 = np.copy(img)
rows,cols = img1.shape[:2]
for row in range(rows):
 for col in range(cols):
  img[row,col] = 255 - img[row,col]
t2 = time.time()
print('方法1所需时间:',t2-t1)

# 方法2
t3 = time.time()
img2 = np.copy(img)
rows,cols = img2.shape[:2]
img2 = img2.reshape(rows*cols)
# print(img2)
for i in range(rows*cols):
 img2[i] = 255-img2[i]
img2 = img2.reshape(rows,cols)
# print(img2)
t4 = time.time()
print('方法2所需时间:',t4-t3)

# 方法3
t5 = time.time()
img3 = np.copy(img)
# 使用多维迭代生成器
for (x,y), pixel in np.ndenumerate(img3):
 img3[x,y] = 255-pixel
t6 = time.time()
print('方法3所需时间:',t6-t5)

测试结果:

方法1所需时间: 0.14431977272033691
方法2所需时间: 0.13863205909729004
方法3所需时间: 0.24196243286132812

以上这篇用python按照图像灰度值统计并筛选图片的操作(PIL,shutil,os)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python装饰器使用实例:验证参数合法性
Jun 24 Python
Python中Collections模块的Counter容器类使用教程
May 31 Python
Python3.x爬虫下载网页图片的实例讲解
May 22 Python
python版本单链表实现代码
Sep 28 Python
详解Django-restframework 之频率源码分析
Feb 27 Python
使用python爬取微博数据打造一颗“心”
Jun 28 Python
Python collections模块使用方法详解
Aug 28 Python
face++与python实现人脸识别签到(考勤)功能
Aug 28 Python
python面向对象之类属性和类方法案例分析
Dec 30 Python
浅谈python的elementtree模块处理中文注意事项
Mar 06 Python
python+opencv边缘提取与各函数参数解析
Mar 09 Python
python使用pyecharts库画地图数据可视化的实现
Mar 25 Python
Python flask框架实现浏览器点击自定义跳转页面
Jun 04 #Python
python 图像判断,清晰度(明暗),彩色与黑白实例
Jun 04 #Python
完美解决ARIMA模型中plot_acf画不出图的问题
Jun 04 #Python
Python使用Matlab命令过程解析
Jun 04 #Python
Python flask框架端口失效解决方案
Jun 04 #Python
Python实现列表中非负数保留,负数转化为指定的数值方式
Jun 04 #Python
Python新手学习装饰器
Jun 04 #Python
You might like
数据库中排序的对比及使用条件详解
2012/02/23 PHP
Codeigniter通过SimpleXML将xml转换成对象的方法
2015/03/19 PHP
php array_map使用自定义的函数处理数组中的每个值
2016/10/26 PHP
PHP5.5安装PHPRedis扩展及连接测试方法
2017/01/22 PHP
Laravel 在views中加载公共页面的实现代码
2019/10/22 PHP
兼容多浏览器的iframe自适应高度(ie8 、谷歌浏览器4.0和 firefox3.5.3)
2009/11/04 Javascript
jQuery EasyUI中对表格进行编辑的实现代码
2010/06/10 Javascript
jQuery实现公告文字左右滚动的实例代码
2013/10/29 Javascript
JQuery中使用.each()遍历元素学习笔记
2014/11/08 Javascript
JavaScript将XML转成JSON的方法
2015/03/12 Javascript
jQuery实现自动滚动到页面顶端的方法
2015/05/22 Javascript
Three.js学习之正交投影照相机
2016/08/01 Javascript
jQuery flip插件实现的翻牌效果示例【附demo源码下载】
2016/09/20 Javascript
BootStrap便签页的简单应用
2017/01/06 Javascript
关于vue-resource报错450的解决方案
2017/07/24 Javascript
AngularJS基于MVC的复杂操作实例讲解
2017/12/31 Javascript
vue.js,ajax渲染页面的实例
2018/02/11 Javascript
详解创建自定义的Angular Schematics
2018/06/06 Javascript
NodeJs项目中关闭ESLint的方法
2018/08/09 NodeJs
Vue项目路由刷新的实现代码
2019/04/17 Javascript
jquery树形插件zTree高级使用详解
2019/08/16 jQuery
JavaScript Array.flat()函数用法解析
2020/09/02 Javascript
在GitHub Pages上使用Pelican搭建博客的教程
2015/04/25 Python
使用python生成杨辉三角形的示例代码
2018/08/29 Python
python通过配置文件共享全局变量的实例
2019/01/11 Python
详解PyTorch手写数字识别(MNIST数据集)
2019/08/16 Python
Python爬虫入门教程02之笔趣阁小说爬取
2021/01/24 Python
HTML5之WebGL 3D概述(下)—借助类库开发及框架介绍
2013/01/31 HTML / CSS
Linux的文件类型
2012/03/07 面试题
追悼会上的答谢词
2014/01/10 职场文书
学生实习介绍信
2014/01/15 职场文书
健康家庭事迹材料
2014/05/02 职场文书
2014组织生活会方案
2014/05/19 职场文书
小学生安全教育主题班会
2015/08/12 职场文书
《鸟的天堂》教学反思
2016/02/19 职场文书
解决Pytorch修改预训练模型时遇到key不匹配的情况
2021/06/05 Python