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()
- python详细讲解类方法的使用(浅谈python标准库--functools.partial)
- python实现sql脚本规范(基于Python的SQL Server数据库实现对象同步轻量级)
- python把str转成list(python3 字符串/列表/元组str/list/tuple相互转换方法及join函数的使用)
- python导出数据到mysql(python定时按日期备份MySQL数据并压缩)
- python爬虫10分钟教程(浅谈Python爬虫基本套路)
- python多进程与多线程详解(Python线程之定位与销毁的实现)
- python数字形式转换详解(Python3.5实现的罗马数字转换成整数功能示例)
- python继承重写构造函数(Python子类继承父类构造函数详解)
- 12步轻松搞定python装饰器(Python3.5装饰器典型案例分析)
- python测试websocket接口(Python如何爬取实时变化的WebSocket数据的方法)
- python中内存管理机制(Python中整数的缓存机制讲解)
- python设置微信(利用python实现在微信群刷屏的方法)
- python爬取微博登录数据(Python实现爬取马云的微博功能示例)
- python读取文件的方法和区别(浅谈PYTHON 关于文件的操作)
- 怎么用python获取目录(python 获得任意路径下的文件及其根目录的方法)
- 如何学会python多线程(Python3多线程基础知识点)
- 微商在朋友圈热卖的 DL减肥咖啡 含违禁药物,你还敢买吗(微商在朋友圈热卖的)
- 八一节,说说中国女兵(八一节说说中国女兵)
- 王治郅菜鸟赛季已让八一带入正轨,大郅七大经典语录或是成功秘诀(王治郅菜鸟赛季已让八一带入正轨)
- 庆八一,重读经典红色语录,感悟互联网发展硬道理(重读经典红色语录)
- TVB新剧《黯夜守护者》将播,陈展鹏陈炜首次合作探讨人性(TVB新剧黯夜守护者将播)
- 新晋小花被称女版吴卓羲 将取代滕丽名成为TVB新一代御用女警(新晋小花被称女版吴卓羲)
热门推荐
- 阿里云centos7java服务器搭建(阿里云 ubuntu16.04搭建IPSec服务)
- html5淘汰的标签(浅谈HTML5新增和废弃的标签)
- python 模块详解(举例讲解Python常用模块)
- css按钮样式实例(CSS使用classList实现两个按钮样式的切换)
- canvas绘制分辨率(通过canvas转换颜色为RGBA格式及性能问题的解决)
- python实现删除列表重复元素功能(Python实现删除排序数组中重复项的两种方法示例)
- php常用执行函数(PHP自动载入类文件函数__autoload的使用方法)
- php框架初始化教程学习(PHP从零开始打造自己的MVC框架之类的自动加载实现方法详解)
- phpredis怎么测试成功(PHP+redis实现的限制抢购防止商品超发功能详解)
- vue设置div大小(Vue实现div滚轮放大缩小)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9