亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python利用線程生成不同尺寸的縮略圖實(shí)例詳解

 更新時(shí)間:2022年05月19日 08:32:35   作者:while10  
這篇文章主要介紹了python利用線程生成不同尺寸的縮略圖,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

利用線程生成縮略圖;
讀取當(dāng)前路徑下的png文件,在當(dāng)前路徑下生成6464,128128和32*32的縮略圖。

"""
利用線程生成縮略圖
讀取當(dāng)前路徑下的png文件,在當(dāng)前路徑下生成64*64,128*128和32*32的縮略圖
"""
import glob
import os
import threading
from PIL import Image
def generate_thumbnail(infile, size):
    """生成指定圖片文件的縮略圖"""
    file, ext = os.path.splitext(infile)
    file = file[file.rfind('/') + 1:]  # 查找文件名
    outfile = f'{file}_{size[0]}_{size[1]}{ext}'  # 生成縮略圖的文件名
    img = Image.open(infile)
    img.thumbnail(size, Image.ANTIALIAS)  # 進(jìn)行縮略圖  size為元組   Image.ANTIALIAS表示低質(zhì)量
    img.save(outfile)
def main():
    """主函數(shù)"""
    for infile in glob.glob('*.png'):  # 查找當(dāng)前路徑下的png文件
        for size in (32, 64, 128):  # 利用線程生成多個(gè)尺寸的縮略圖
            # 創(chuàng)建并啟動(dòng)線程
            threading.Thread(
                target=generate_thumbnail,
                args=(infile, (size, size))
            ).start()
if __name__ == '__main__':
    main()

補(bǔ)充:python 縮放并裁剪圖片 制作圖片縮略圖

說(shuō)明

現(xiàn)在有一文件夾中存在許多分辨率不同的圖片或文件夾,需要裁剪至指定大小以便作為網(wǎng)頁(yè)中的圖片縮略圖。
cut 函數(shù),將圖片裁剪為指定大小,統(tǒng)一分辨率,縮放后取圖片中間部分,超出的部分直接裁剪掉。
還有一個(gè)函數(shù) cut2,為等比縮放至x或y為定值。

用法

縮放裁剪后的x、y像素值在代碼開始部分更改即可。
默認(rèn)只使用 cut 函數(shù),使用 cut2 函數(shù)時(shí)需在代碼第18-20行更改。

注意:

1.縮放裁剪后會(huì)覆蓋原文件,需要的話,請(qǐng)?jiān)诳s放裁剪前備份圖片。

2.沒(méi)有做文件夾驗(yàn)證,請(qǐng)確認(rèn)輸入正確的文件夾路徑,并確保文件夾中只有圖片。

3.多次縮放可能會(huì)使圖片變得模糊,尤其是文字邊緣。

完整代碼

import cv2
import os
import numpy as np
# cut 裁剪后的 xy
target_x = 286
target_y = 203
def get_dir(dir):
?? ?""" 遍歷文件夾下所有的文件名 """
?? ?list1 = os.listdir(dir)
?? ?for l in list1:
?? ??? ?l = f'{dir}/{l}'
?? ??? ?if(os.path.isdir(l)):
?? ??? ??? ?get_dir(l)
?? ??? ?else:
?? ??? ??? ?cut(l)
?? ??? ??? ?# cut2(l,x=800)
?? ??? ??? ?# cut2(l,y=400)
def cut(inputdir = './t.jpg'):
?? ?""" 圖片裁剪 """
?? ?# 裁剪后的文件名為
?? ?# outputdir = inputdir[:-4] + '_over.jpg'
?? ?# 設(shè)置為相同文件名,覆蓋原文件
?? ?outputdir = inputdir
?? ?# img = cv2.imread(inputdir)?? ?# imread讀取不能包含中文文件名
?? ?img = cv2.imdecode(np.fromfile(inputdir, dtype=np.uint8), cv2.IMREAD_UNCHANGED)
? ? # imdecode讀取圖像默BGR通道排列,?
? ? # img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)?? ?# 轉(zhuǎn)換為RGB
?? ?# img.shape:[height,width,channel]
?? ?in_y, in_x = img.shape[:2]
?? ?print(img.shape)
?? ?scale = target_x / target_y
?? ?scale1 = in_x / in_y
?? ?if(scale1 >= scale):
?? ??? ?size = (int(in_x/(in_y/target_y)), target_y)
?? ??? ?# print(1, size)
?? ?elif(scale1 < scale):
?? ??? ?size = (target_x, int(in_y/(in_x/target_x)))
?? ??? ?# print(2, size)
?? ?else:
?? ??? ?size = (target_x, target_y)
?? ??? ?print('error')
?? ?# 縮放到size=(x,y)
?? ?resized = cv2.resize(img, size, interpolation=cv2.INTER_AREA)
?? ?# 展示裁剪后的圖片
?? ?# cv2.imshow('image', resized)
?? ?# cv2.waitKey(0)
?? ?# print('x', resized.shape[1], 'y', resized.shape[0])
?? ?if(resized.shape[1] == target_x):
?? ??? ?# x=target_x
?? ??? ?y0 = resized.shape[0] // 2 - target_y//2
?? ??? ?y1 = y0 + target_y
?? ??? ?x0 = 0
?? ??? ?x1 = target_x
?? ?if(resized.shape[0] == target_y):
?? ??? ?# y=target_y
?? ??? ?y0 = 0
?? ??? ?y1 = target_y
?? ??? ?x0 = resized.shape[1] // 2 - target_x//2
?? ??? ?x1 = x0 + target_x
?? ?output_img = resized[y0:y1, x0:x1]
?? ?# cv2.imwrite(outputdir, output_img)?? ?# imwrite保存文件名不能包含中文
?? ?cv2.imencode('.jpg', output_img)[1].tofile(outputdir)
def cut2(inputdir = './t.jpg', x=0, y=0):
?? ?""" 等比縮放,不裁剪 """
?? ?# outputdir = inputdir[:-4] + '_over.jpg'
?? ?outputdir = inputdir
?? ?img = cv2.imdecode(np.fromfile(inputdir, dtype=np.uint8), cv2.IMREAD_UNCHANGED)
?? ?in_y, in_x = img.shape[:2]
?? ?if(x):
?? ??? ?# 等比縮小為x=
?? ??? ?fxy = x/in_x
?? ?elif(y):
?? ??? ?# 等比縮小為y=
?? ??? ?fxy = y/in_y
?? ?else:
?? ??? ?fxy = 1
?? ?# 按比例縮放,fx:x軸縮放比例,fy:y軸縮放比例
?? ?output_img = cv2.resize(img, (0,0), fx=fxy, fy=fxy, interpolation=cv2.INTER_AREA)
?? ?cv2.imencode('.jpg', output_img)[1].tofile(outputdir)
if __name__ == "__main__":
?? ?original_dir = input('文件夾路徑:')
?? ?get_dir(original_dir)

到此這篇關(guān)于python利用線程生成不同尺寸的縮略圖的文章就介紹到這了,更多相關(guān)python生成縮略圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • windows系統(tǒng)中python使用rar命令壓縮多個(gè)文件夾示例

    windows系統(tǒng)中python使用rar命令壓縮多個(gè)文件夾示例

    這篇文章主要介紹了windows系統(tǒng)中python使用rar命令壓縮多個(gè)文件夾示例,需要的朋友可以參考下
    2014-05-05
  • Python判斷文件和文件夾是否存在的方法

    Python判斷文件和文件夾是否存在的方法

    這篇文章主要介紹了Python判斷文件和文件夾是否存在的方法,本文還講解了判斷是否為文件或者目錄的方法、os.path.lexist的作用、FTP中判斷文件或目錄是否存在等內(nèi)容,需要的朋友可以參考下
    2015-05-05
  • pytorch 修改預(yù)訓(xùn)練model實(shí)例

    pytorch 修改預(yù)訓(xùn)練model實(shí)例

    今天小編就為大家分享一篇pytorch 修改預(yù)訓(xùn)練model實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-01-01
  • 使用Python實(shí)現(xiàn)音頻雙通道分離

    使用Python實(shí)現(xiàn)音頻雙通道分離

    這篇文章主要介紹了使用Python實(shí)現(xiàn)音頻雙通道分離的方法,幫助大家更好的理解和使用python,感興趣的朋友可以了解下
    2020-12-12
  • Python游戲開發(fā)之精靈和精靈組

    Python游戲開發(fā)之精靈和精靈組

    python作為當(dāng)前非常受歡迎的編程語(yǔ)言,很大一部分原因是擁有豐富的庫(kù),這篇文章主要給大家介紹了關(guān)于Python游戲開發(fā)之精靈和精靈組的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 基于DATAFRAME中元素的讀取與修改方法

    基于DATAFRAME中元素的讀取與修改方法

    今天小編就為大家分享一篇基于DATAFRAME中元素的讀取與修改方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • torch.optim優(yōu)化算法理解之optim.Adam()解讀

    torch.optim優(yōu)化算法理解之optim.Adam()解讀

    這篇文章主要介紹了torch.optim優(yōu)化算法理解之optim.Adam()解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • pygame實(shí)現(xiàn)五子棋游戲

    pygame實(shí)現(xiàn)五子棋游戲

    這篇文章主要為大家詳細(xì)介紹了pygame實(shí)現(xiàn)五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • Python實(shí)現(xiàn)找出數(shù)組中第2大數(shù)字的方法示例

    Python實(shí)現(xiàn)找出數(shù)組中第2大數(shù)字的方法示例

    這篇文章主要介紹了Python實(shí)現(xiàn)找出數(shù)組中第2大數(shù)字的方法,涉及Python針對(duì)數(shù)組的排序、遍歷等相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • Python 讀取WAV音頻文件 畫頻譜的實(shí)例

    Python 讀取WAV音頻文件 畫頻譜的實(shí)例

    這篇文章主要介紹了Python 讀取WAV音頻文件 畫頻譜的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-03-03

最新評(píng)論