欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

python實(shí)現(xiàn)無損批量壓縮圖片-創(chuàng)新互聯(lián)

python 實(shí)現(xiàn)無損批量壓縮圖片?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

創(chuàng)新互聯(lián)一直在為企業(yè)提供服務(wù),多年的磨煉,使我們?cè)趧?chuàng)意設(shè)計(jì),成都全網(wǎng)營銷推廣到技術(shù)研發(fā)擁有了開發(fā)經(jīng)驗(yàn)。我們擅長傾聽企業(yè)需求,挖掘用戶對(duì)產(chǎn)品需求服務(wù)價(jià)值,為企業(yè)制作有用的創(chuàng)意設(shè)計(jì)體驗(yàn)。核心團(tuán)隊(duì)擁有超過十余年以上行業(yè)經(jīng)驗(yàn),涵蓋創(chuàng)意,策化,開發(fā)等專業(yè)領(lǐng)域,公司涉及領(lǐng)域有基礎(chǔ)互聯(lián)網(wǎng)服務(wù)西信服務(wù)器托管成都App定制開發(fā)、手機(jī)移動(dòng)建站、網(wǎng)頁設(shè)計(jì)、網(wǎng)絡(luò)整合營銷。

1、批量壓縮照片

新建 photo_compress.py 代碼如下

# -*- coding: utf-8 -*-

"""腳本功能說明:使用 tinypng api,一鍵批量壓縮指定文件(夾)所有文件"""

import os
import sys
from concurrent.futures import ThreadPoolExecutor, ProcessPoolExecutor # 線程池,進(jìn)程池
import json
import random
import requests
from you_get import common
from shutil import copyfile


def get_file_dir(file):
 """獲取文件目錄通用函數(shù)"""
 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'只支持png\\jpg\\jepg格式文件:' + 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("開始?jí)嚎s")
  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'報(bào)錯(cuò)了:%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'目標(biāo)文件(夾)不存在,請(qǐng)確認(rèn)后重試。')


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 images


def 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'報(bào)錯(cuò)了:%s' % e)
  if file:
   file.close()
 if result and result['input'] and result['output']:
  return result
 else:
  return None


def 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個(gè)線程執(zhí)行此任務(wù)
 download_thread_pool = ThreadPoolExecutor(10) # 定義5個(gè)線程執(zhí)行此任務(wù)
 process_pool = ProcessPoolExecutor(8) # 定義5個(gè)進(jìn)程
 len_param = len(sys.argv)
 if len_param != 2 and len_param != 3:
  print('請(qǐng)使用: %s [filepath]' % os.path.basename(sys.argv[0]))
 else:
  check_path(sys.argv[1])
  input("Press <enter> 請(qǐng)耐心等待\n")

分享標(biāo)題:python實(shí)現(xiàn)無損批量壓縮圖片-創(chuàng)新互聯(lián)
分享鏈接:http://aaarwkj.com/article0/ggeoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、外貿(mào)網(wǎng)站建設(shè)網(wǎng)站制作、關(guān)鍵詞優(yōu)化自適應(yīng)網(wǎng)站、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計(jì)公司
国产成人亚洲精品另类动态| 亚洲三级av在线播放| 日韩国产欧美一区二区在线视频 | 久久精品性少妇一区=区三区| 国产麻豆91在线视频| 午夜福利在线视频观看| 国语自产拍在线观看不卡| 欧美日韩国产激情另类| 人人妻人人澡人人爽人人精品| 亚洲国产成人精品女人久久久′| 男女搞j视频网站免费观看 | 亚洲国产欧美日韩在线| 欧美熟妇在线视频你懂的| 久久亚洲女同第一区综合| 色婷婷狠狠久久综合中文一本| 久久热这里只有精品网站| 精品人妻区二区三区蜜桃| 免费观看日本成人午夜大片| 99精品一二三日韩| 国产国产乱老熟视频网站| 国产在线精品专区第一页| 日韩在线啊啊啊的视频| 视频一区视频二区三区| 三级视频一区二区三区| 午夜一区二区精品视频国产| 亚洲自偷精品视频自拍| 日韩熟女av中文字幕| 亚洲免费黄色大片网站| 欧美日韩电影一区二区三区| 一级黄片国产精品久久| 久久亚洲一区二区三区乱码| 日本在线免费观看91 | 最新天堂av资源在线观看| 日本免费精品一区二区三区中| 精品一区中文字幕少妇人妻 | 欧美黄色一区在线观看| 国产在线一区二区三区观看| 国产综合精品一区二区| 精品久久精品久久人妻九色| 亚洲国产成人精品女人| 久青青国产综合自拍视频在线观看|