python自动处理图片(python制作图片缩略图)
python自动处理图片
python制作图片缩略图缩略图
在很多时候我们都需要将图片按照同比例缩小有利于存储 但是一张张手动去改的话太麻烦了 今天我们就用python实现一个简单的将一个文件夹中的所有图片进行指定大小的调整
缩略前:
代码:
|
import os import glob from pil import image def thumbnail_pic(path): #glob.glob(pathname),返回所有匹配的文件路径列表 a = glob.glob(r './img/*.jpg" alt="python自动处理图片(python制作图片缩略图)" border="0" /> for x in a: name = os.path.join(path,x) im = image. open (name) im.thumbnail(( 80 , 80 )) print (im. format ,im.size,im.mode) im.save(name, '.jpg" alt="python自动处理图片(python制作图片缩略图)" border="0" /> print ( 'done!' ) if __name__ = = '__main__' : path = '.' thumbnail_pic(path) |
缩略后:
参数使用说明:
1、os模块,python的os模块封装了常见的文件和目录操作。
2、pil模块中image类thumbnail()方法可以用来制作缩略图,它接受一个二元数组作为缩略图的尺寸,然后将示例缩小到指定尺寸。
image.resize()和image.thumbnail()的区别
根据代码和代码注释, 这两个函数都是对图片进行缩放, 两者的主要区别如下:
- resize()函数会返回一个image对象, thumbnail()函数返回none
- resize()修改后的图片在返回的image中, 而原图片没有被修改;
- thumbnail()直接对内存中的原图进行了修改, 但是修改需要保存
- resize()中的size参数直接设定了resize之后图片的规格,而thumbnail()中的size参数则是设定了x/y上的最大值. 也就是说, 经过resize()处理的图片可能会被拉伸,而经过thumbnail()处理的图片不会被拉伸
- thumbnail()函数内部调用了resize(), 可以认为thumbnail()是对resize()的一种封装
使用scrapy爬虫框架制作缩略图
images pipeline为处理图片提供了额外的功能:
- 将所有下载的图片格式转换成普通.jpg" alt="python自动处理图片(python制作图片缩略图)" border="0" />
- 生成缩略图
- 检查图片的宽度和高度确保它们满足最小的尺寸限制
管道同时会在内部保存一个被调度下载的url列表,然后将包含相同媒体的相应关联到这个队列上来,从而防止了多个item共享这个媒体时重复下载。
imagespipeline使用pillow来生成缩略图以及转换成标准.jpg" alt="python自动处理图片(python制作图片缩略图)" border="0" />
配置setting.py
pipeline.py文件
items.py
以上为个人使用scrapy保存缩略图的总结。
原文链接:https://blog.csdn.net/qq_37275405/article/details/81139776
# 同时使用图片和文件管道
item_pipelines
=
{
'scrapy.pipelines.images.imagespipeline'
:
1
,
'scrapy.pipelines.files.filespipeline'
:
2
,
}
# 指定图片字段
images_urls_field
=
'images'
images_store
=
'/path/to/valid/dir'
# 图片存储路径
# 文件过期90天
files_expires
=
90
# 图像过期延迟30天
images_expires
=
30
# 图片缩略图
images_thumbs
=
{
'small'
: (
50
,
50
),
'big'
: (
270
,
270
),
}
# 图片过滤器,最小高度和宽度
images_min_height
=
110
images_min_width
=
110
class
yuehuiimagepipeline(imagespipeline):
def
item_completed(
self
, results, item, info):
if
results[
0
][
0
]:
item[
'image_path'
]
=
results[
0
][
1
][
'path'
]
else
:
item[
'image_path'
]
=
''
return
item
class
yuehuiitem(scrapy.item):
uid
=
scrapy.field()
height
=
scrapy.field()
weight
=
scrapy.field()
images
=
scrapy.field()
#头像url字段 要求列表 在setting文件中配置
image_path
=
scrapy.field()
- opencv提取图像轮廓python代码(Python基于opencv调用摄像头获取个人图片的实现方法)
- python如何编写判断正负数程序(Python实现判断一个整数是否为回文数算法示例)
- python做了一个自动翻译的小工具(Python 20行简单实现有道在线翻译的详解)
- python3下urllib案例(URL Rewrite Module 2.1 URL重写模块规则写法)
- pythonide使用教程(对Python Pexpect 模块的使用说明详解)
- pythontkinter循环显示文本(Python实现定时自动关闭的tkinter窗口方法)
- python分析excel基础数据生成报表(Python实现定制自动化业务流量报表周报功能XlsxWriter模块)
- python中如何定义带走参数的函数(Python函数定义及传参方式详解4种)
- python入门练习网页(详解python项目实战:模拟登陆CSDN)
- python数据存取(python异步存储数据详解)
- python程序开发过程(python调用外部程序的实操步骤)
- python与气象(使用Python和Prometheus跟踪天气的使用方法)
- python教程列表排序(Python一行代码实现快速排序的方法)
- python使用aes加密解密(python实现AES加密与解密)
- python面向对象编写案例(Python面向对象程序设计示例小结)
- python爬虫入门代码(python爬虫基础教程:requests库二代码实例)
- 为什么越来越多年轻人回农村(为什么越来越多年轻人回农村生活)
- 怎么快速学好英语(怎么快速学好英语初中)
- 中国留学生都是富二代吗()
- 我们现在吃的苹果是哪里来的 原来现代苹果引入中国仅有一百多年(我们现在吃的苹果是哪里来的)
- 买绿宝不能只挑黄绿色 菜农教你3招挑,个个皮薄肉脆,香甜爆汁(买绿宝不能只挑黄绿色)
- 大果肉搭配薄瓜皮, 绿宝 脆甜爽口,不愧是甜瓜中的 佼佼者(大果肉搭配薄瓜皮)
热门推荐
- linux系统显示时间的命令(详解Linux time 命令的使用)
- navicat注册和激活码(Navicat12.1系列破解激活教程亲测有效)
- python怎么去掉字符串的空格(Python切片操作去除字符串首尾的空格)
- sqlserver数字格式化五位小数(详细分析sqlserver中的小数类型float和decimal)
- docker-compose命令(docker-compose教程之安装使用和快速入门)
- Visual Studio 编译中活动平台AnyCPU
- 租用服务器收费标准(网站服务器租用多少钱?)
- sqlserver 查询锁(sqlserver:查询锁住sql以及解锁方法)
- mysql binlog模式实际使用(实例验证MySQL|update字段为相同的值是否会记录binlog)
- html5 webrtc技术详解(Html5 webRTC简单实现视频调用的示例代码)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9