日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

python 無損批量壓縮圖片(支持保留圖片信息)的示例

瀏覽:25日期:2022-07-10 13:57:23

由于云盤空間有限,照片尺寸也是很大,所以寫個Python程序壓縮一下照片,騰出一些云盤空間

1、批量壓縮照片

新建 photo_compress.py 代碼如下

# -*- coding: utf-8 -*-'''腳本功能說明:使用 tinypng api,一鍵批量壓縮指定文件(夾)所有文件'''import osimport sysfrom concurrent.futures import ThreadPoolExecutor, ProcessPoolExecutor # 線程池,進程池import jsonimport randomimport requestsfrom you_get import commonfrom shutil import copyfiledef get_file_dir(file): '''獲取文件目錄通用函數''' fullpath = os.path.abspath(os.path.realpath(file)) return os.path.dirname(fullpath)def check_suffix(file_path): '''檢查指定文件的后綴是否符合要求''' file_path_lower = file_path.lower() return (file_path_lower.endswith(’.png’) or file_path_lower.endswith(’.jpg’) or file_path_lower.endswith(’.jpeg’))def download_tinypng(input_file, url, output_file): file_name = os.path.basename(input_file) arr = file_name.split(’.’) new_file_name = arr[len(arr) - 2] + ’_compress’ new_output_file = os.path.join(os.path.dirname(output_file), arr[len(arr) - 2] + ’_compress.’ + arr[len(arr) - 1]) print(u’開始下載文件 :%s’ % new_output_file) # print(os.path.splitext(os.path.basename(output_file))[0]) sys.argv = [’you-get’, ’-o’, os.path.dirname( output_file), ’-O’, new_file_name, url] common.main() old_size = os.path.getsize(input_file) new_size = os.path.getsize(new_output_file) print(u’文件保存地址:%s’ % new_output_file) print(u’壓縮后文件大小:%d KB’ % (new_size / 1024)) print(u’壓縮比: %d%%’ % ((old_size - new_size) * 100 / old_size))def compress_by_tinypng(input_file): if not check_suffix(input_file): print(u’只支持pngjpgjepg格式文件:’ + input_file) return file_name = os.path.basename(input_file) arr = file_name.split(’.’) new_file_name = arr[len(arr) - 2] + ’_compress.’ + arr[len(arr) - 1] output_path = os.path.join(get_file_dir(input_file), ’compress_output’) output_file = os.path.join(output_path, new_file_name) if not os.path.isdir(output_path): os.makedirs(output_path) if (os.path.exists(output_file)): print('已存在,跳過壓縮') return try: old_size = os.path.getsize(input_file) print(u’壓縮前文件名:%s文件大小:%d KB’ % (input_file, old_size / 1024)) if (old_size < 1024 * 1024): print('已跳過壓縮,并直接拷貝文件') try: copyfile(input_file, output_file) except IOError as e: print('Unable to copy file. %s' % e) return print('開始壓縮') shrink_image(input_file) print(u’文件壓縮成功:%s’ % input_file) # download_thread_pool.submit(download_tinypng, source, input_file, output_file) except Exception as e: print(u’報錯了:%s’ % e)def check_path(input_path): '''如果輸入的是文件則直接壓縮,如果是文件夾則先遍歷''' if os.path.isfile(input_path): compress_by_tinypng(input_path) elif os.path.isdir(input_path): dirlist = os.walk(input_path) for root, dirs, files in dirlist: if (not (root.endswith('compress_output') or root.endswith('/compress_output'))): i = 0 for filename in files: i = i + 1 process_pool.submit(compress_by_tinypng, os.path.join( root, filename)) # compress_by_tinypng(os.path.join(root, filename)) else: print(u’目標文件(夾)不存在,請確認后重試。’)def list_images(path): images = None try: if path: os.chdir(path) full_path = os.getcwd() files = os.listdir(full_path) images = [] for file in files: ext = os.path.splitext(file)[1].lower() if ext in (’.jpg’, ’.jpeg’, ’.png’): images.append(os.path.join(full_path, file)) except: pass return imagesdef shrink_image(file_path): print(u’源文件地址:%s’ % file_path) result = shrink(file_path) if result: output_path = generate_output_path(file_path) url = result[’output’][’url’] print(u’下載地址:%s’ % url) download_tinypng(file_path, url, output_path) # download_thread_pool.submit(download_tinypng, file_path, url, output_path) # response = requests.get(url) # with open(output_path, ’wb’) as file: # file.write(response.content) # print(u’文件保存地址:%s’ % output_path) # print(’%s %d=>%d(%f)’ % ( # result[’input’][’type’], # result[’input’][’size’], # result[’output’][’size’], # result[’output’][’ratio’] # )) else: print(’壓縮失敗’)def shrink(file_path): url = ’https://tinypng.com/web/shrink’ headers = { ’Cache-Control’: ’no-cache’, ’Content-Type’: ’application/x-www-form-urlencoded’, ’User-Agent’: ’Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.83 Safari/537.36 Edg/85.0.564.44’, ’X-Forwarded-For’: get_random_ip() } result = None try: file = open(file_path, ’rb’) response = requests.post(url, headers=headers, data=file) result = json.loads(response.text) except Exception as e: print(u’報錯了:%s’ % e) if file: file.close() if result and result[’input’] and result[’output’]: return result else: return Nonedef generate_output_path(file_path): parent_path = os.path.abspath(os.path.dirname(file_path)) output_path = os.path.join(parent_path, ’compress_output’) if not os.path.isdir(output_path): os.mkdir(output_path) return os.path.join(output_path, os.path.basename(file_path))def get_random_ip(): ip = [] for i in range(4): ip.append(str(random.randint(0 if i in (2, 3) else 1, 254))) return ’.’.join(ip)if __name__ == ’__main__’: thread_pool = ThreadPoolExecutor(5) # 定義5個線程執行此任務 download_thread_pool = ThreadPoolExecutor(10) # 定義5個線程執行此任務 process_pool = ProcessPoolExecutor(8) # 定義5個進程 len_param = len(sys.argv) if len_param != 2 and len_param != 3: print(’請使用: %s [filepath]’ % os.path.basename(sys.argv[0])) else: check_path(sys.argv[1]) input('Press <enter> 請耐心等待n')

執行python .photo_compress.py F:test

python 無損批量壓縮圖片(支持保留圖片信息)的示例

生成compress_output文件夾,里面就是壓縮的文件,但此時的照片沒有,拍攝時的時間、位置的信息,所以下面要復制文件信息

若要壓縮的文件不全,可以再執行一次壓縮(會自動過濾已壓縮的照片)

2、批量拷貝照片信息

使用pyexiv2進行文件信息拷貝

pip install pyexiv2 -i https://pypi.tuna.tsinghua.edu.cn/simple

新建 copy_fileinfo.py 代碼如下

# -*- coding: utf-8 -*-'''腳本功能說明:使用 pyexiv2 api,一鍵批量拷貝指定文件(夾)所有文件信息'''import osimport sysfrom concurrent.futures import ThreadPoolExecutor, ProcessPoolExecutor # 線程池,進程池from pyexiv2 import Imagedef get_file_dir(file): '''獲取文件目錄通用函數''' fullpath = os.path.abspath(os.path.realpath(file)) return os.path.dirname(fullpath)def check_suffix(file_path): '''檢查指定文件的后綴是否符合要求''' file_path_lower = file_path.lower() return (file_path_lower.endswith(’.png’) or file_path_lower.endswith(’.jpg’) or file_path_lower.endswith(’.jpeg’))def copyinfo_by_pyexiv2(input_file): file_name = os.path.basename(input_file) arr = file_name.split(’.’) new_file_name = arr[len(arr) - 2] + ’_compress.’ + arr[len(arr) - 1] output_path = os.path.join(get_file_dir(input_file), ’compress_output’) output_file = os.path.join(output_path, new_file_name) if not (check_suffix(input_file) or check_suffix(output_file)): print(u’只支持pngjpgjepg格式文件:’ + input_file) return if not (os.path.exists(output_file)): print(u’文件不存在:’ + output_file) return old_size = os.path.getsize(input_file) if (old_size < 1024 * 1024): print(u'已跳過拷貝文件信息:', input_file) return # if not os.path.isdir(output_path): # os.makedirs(output_path) try: i = Image(input_file) # 源圖片路徑 except Exception: i = Image(input_file, 'GB18030') try: _exif_info = i.read_exif() except Exception: _exif_info = i.read_exif('GB18030') # print(_exif_info) # _iptc_info = i.read_iptc() # print(_iptc_info) # _xmp_info = i.read_xmp() # print(_xmp_info) i.close() try: i2 = Image(output_file) # 拷貝信息圖片路徑 except Exception: i2 = Image(output_file, 'GB18030') try: _exif_info2 = i2.read_exif() except Exception: _exif_info2 = i2.read_exif('GB18030') # 方向不拷貝,防止圖片旋轉 for item in _exif_info: if('Exif.Image.Orientation' != item): if (_exif_info2.get(item) != _exif_info.get(item)): try: i2.modify_exif({item: _exif_info[item]}) except Exception as e: print(e) try: i2.modify_exif({item: _exif_info[item]}, 'GB18030') except Exception as e: print(e) i2.close() print(u'拷貝信息完成:' + input_file)def check_path(input_path): '''如果輸入的是文件則直接壓縮,如果是文件夾則先遍歷''' if os.path.isfile(input_path): copyinfo_by_pyexiv2(input_path) elif os.path.isdir(input_path): dirlist = os.walk(input_path) for root, dirs, files in dirlist: if (not (root.endswith('compress_output') or root.endswith('/compress_output'))): i = 0 for filename in files: i = i + 1 process_pool.submit(copyinfo_by_pyexiv2, os.path.join( root, filename)) else: print(u’目標文件(夾)不存在,請確認后重試。’)if __name__ == ’__main__’: # thread_pool = ThreadPoolExecutor(10) # 定義5個線程執行此任務 process_pool = ProcessPoolExecutor(8) # 定義5個進程 len_param = len(sys.argv) if len_param != 2: print(’請使用: %s [filepath]’ % os.path.basename(sys.argv[0])) else: check_path(sys.argv[1]) input('Press <enter> 請耐心等待n')

執行python .copy_fileinfo.py F:test

大功告成!圖片壓縮完畢,信息還沒有丟失

以上就是python 無損批量壓縮圖片(支持保留圖片信息)的示例的詳細內容,更多關于python 無損批量壓縮圖片的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
免费精品国产| 高清不卡一区| 久久九九99| 欧美日韩精品免费观看视欧美高清免费大片 | 国产日产精品_国产精品毛片 | 综合日韩av| 美日韩一区二区三区| 国产成人精品一区二区三区免费| 国产一区二区精品福利地址| 亚洲欧洲高清| 欧美亚洲国产激情| 欧美精选一区二区三区| 国产精品色网| 日韩精品久久理论片| 国产精品mv在线观看| 日本不良网站在线观看| 亚洲主播在线| 国产日韩一区二区三区在线 | 免播放器亚洲一区| 日韩av一级片| 国产一区精品福利| 99精品小视频| 日韩在线一二三区| 日韩高清不卡在线| 国产成人a视频高清在线观看| 日韩欧美一区二区三区在线观看 | 成人午夜网址| 最新亚洲激情| 国产一区 二区| 快播电影网址老女人久久| 99亚洲视频| 日日夜夜免费精品视频| 国产一区二区三区网| 女人天堂亚洲aⅴ在线观看| 日韩精品亚洲专区在线观看| 高清精品久久| 中文不卡在线| 福利一区和二区| 极品日韩av| 欧美日韩伊人| 亚洲午夜黄色| 国产乱码精品一区二区亚洲| 久久久精品五月天| 日韩精品亚洲专区在线观看| 九色porny丨国产首页在线| 亚洲综合婷婷| 日韩国产专区| 日本综合视频| 欧美亚洲国产精品久久| 国产精品一区二区三区www| 婷婷中文字幕一区| 欧美激情综合| 免费日韩av片| а√天堂中文在线资源8| 亚洲色图国产| 蜜桃视频在线网站| 国产精品久av福利在线观看| 欧美日韩国产欧| 老牛国内精品亚洲成av人片| 免费看的黄色欧美网站| 国产不卡精品在线| 免费精品视频最新在线| 成人亚洲欧美| 国产精品自在| 久久午夜视频| 亚洲播播91| 国产精品久久久久久久久免费高清 | 午夜精品免费| 国产精品22p| 天堂成人免费av电影一区| 亚洲国产欧美日本视频| 久久国际精品| 蜜臀av性久久久久蜜臀aⅴ四虎 | 亚洲国产成人精品女人| 国产一区二区三区精品在线观看| 青青国产精品| 美女精品一区| 欧美亚洲国产激情| 欧洲精品一区二区三区| 精品一区不卡| 亚欧洲精品视频在线观看| 婷婷综合社区| 999国产精品永久免费视频app| 国语对白精品一区二区| 国产精品一区二区av日韩在线| 蜜臀91精品一区二区三区| 伊人久久婷婷| 91精品在线观看国产| 黄毛片在线观看| 欧美亚洲tv| 欧美日韩视频免费看| 日韩成人精品一区二区三区 | www.51av欧美视频| 久久只有精品| 九九九精品视频| 国产精品**亚洲精品| 91精品丝袜国产高跟在线| 日精品一区二区三区| 中文在线日韩| 亚洲区第一页| 亚洲v天堂v手机在线| 亚洲综合婷婷| 日韩午夜视频在线| 91精品国产自产在线丝袜啪| 日韩高清不卡一区| 青草久久视频| 欧美日韩午夜电影网| 91p九色成人| 国产欧美日韩在线观看视频| 国产精品亚洲四区在线观看| 国产精品三级| 欧美激情日韩| 97精品在线| 久久久精品五月天| 免费视频一区三区| 先锋影音国产一区| 日韩精品三级| 麻豆91精品91久久久的内涵| 免费亚洲婷婷| 成人影视亚洲图片在线| 日韩专区精品| 久久久国产亚洲精品| 亚洲精品极品少妇16p| 久久福利影视| 天堂成人免费av电影一区| 日韩激情综合| 久久精品免费看| 亚洲成人va| 国产精品婷婷| 亚洲精品伊人| 麻豆精品久久| 欧美aa在线观看| 亚洲免费中文| 日韩1区2区日韩1区2区| 国产精品777777在线播放 | 日本视频在线一区| 久久爱www.| 日韩美女一区二区三区在线观看| 美女亚洲一区| 日韩欧美在线精品| 精品精品国产三级a∨在线| 91看片一区| 视频在线观看91| 国产精品对白| 精品免费av在线| 亚洲久久视频| 免费在线观看一区| 亚洲精品99| 国产日产高清欧美一区二区三区| 国产 日韩 欧美 综合 一区| 久久久精品午夜少妇| 亚洲毛片视频| 国产一区二区三区精品在线观看| 精品在线91| 国产亚洲一区二区三区啪| 久久久久国产精品一区三寸 | 91精品精品| 国产亚洲一卡2卡3卡4卡新区| 亚洲爱爱视频| 日韩中文一区二区| 国产精品久久久久av电视剧| 亚洲欧美在线综合| 天堂中文av在线资源库| 日韩精品一二三四| 欧美一级鲁丝片| 日韩欧美中文字幕在线视频| 日本免费久久| 清纯唯美亚洲综合一区| 亚洲二区三区不卡| 久久精品色播| 蜜桃av一区二区在线观看| 中文字幕高清在线播放| 日韩欧美久久| 欧美日韩国产在线观看网站| 精品色999| 四虎精品永久免费| 亚洲午夜av| 水蜜桃精品av一区二区| 亚州欧美在线| 最新日韩欧美| 色综合www| 欧美激情麻豆| 日韩成人精品一区二区三区| 亚洲精品在线观看91| 日韩免费视频| 久久国产精品美女| 亚洲日产国产精品| 九九综合九九| 成人亚洲一区二区| 免费看久久久| 日韩精品午夜视频| 久久一二三区| 亚洲激情欧美| 日韩在线高清| 岛国精品一区| 国产精品va视频| 欧美欧美黄在线二区| 亚洲午夜久久| 国产视频一区免费看| 久久激情网站|