当前位置:脚本大全 > > 正文

python自动处理图片(python制作图片缩略图)

时间:2021-10-13 00:09:36类别:脚本大全

python自动处理图片

python制作图片缩略图

缩略图

在很多时候我们都需要将图片按照同比例缩小有利于存储 但是一张张手动去改的话太麻烦了 今天我们就用python实现一个简单的将一个文件夹中的所有图片进行指定大小的调整

缩略前:

python自动处理图片(python制作图片缩略图)

代码:

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 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)
  • 缩略后:

    python自动处理图片(python制作图片缩略图)

    参数使用说明:

    1、os模块,python的os模块封装了常见的文件和目录操作。
    2、pil模块中image类thumbnail()方法可以用来制作缩略图,它接受一个二元数组作为缩略图的尺寸,然后将示例缩小到指定尺寸。

    image.resize()和image.thumbnail()的区别
    根据代码和代码注释, 这两个函数都是对图片进行缩放, 两者的主要区别如下:

    使用scrapy爬虫框架制作缩略图

    images pipeline为处理图片提供了额外的功能:

    管道同时会在内部保存一个被调度下载的url列表,然后将包含相同媒体的相应关联到这个队列上来,从而防止了多个item共享这个媒体时重复下载。

    imagespipeline使用pillow来生成缩略图以及转换成标准.jpg" alt="python自动处理图片(python制作图片缩略图)" border="0" />

    配置setting.py

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • # 同时使用图片和文件管道
  • 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
  • pipeline.py文件

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 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
  • items.py

  • ?
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • class yuehuiitem(scrapy.item):
  •  uid= scrapy.field()
  •  height = scrapy.field()
  •  weight = scrapy.field()
  •  images = scrapy.field() #头像url字段 要求列表 在setting文件中配置
  •  image_path = scrapy.field()
  • 以上为个人使用scrapy保存缩略图的总结。

    原文链接:https://blog.csdn.net/qq_37275405/article/details/81139776

    标签:
    上一篇下一篇

    猜您喜欢

    热门推荐