python實現批量修改圖片格式和尺寸-創新互聯

本文實例為大家分享了python批量處理圖片的具體代碼,供大家參考,具體內容如下

成都創新互聯是一家專業提供定海企業網站建設,專注與網站設計制作、成都網站建設、H5技術、小程序制作等業務。10年已為定海眾多企業、政府機構等服務。創新互聯專業的建站公司優惠進行中。

公司的一個項目要求把所有4096x4096的圖片全部轉化成2048x2048的圖片,這種批量轉換圖片大小的軟件網上很多,我的同事原來使用的美圖看看的批量轉換,但是稍微有點麻煩,每次還需要指定要轉換的圖片的輸入路徑和輸出路徑,而且每次都只能處理一個文件夾,很繁瑣,于是我想到了萬能的Python,然后寫了一個腳本來批量處理圖片,同一個根目錄下的所有文件夾的子文件等的圖片全部會處理掉。

代碼中還加入了很多的異常捕獲機制和提示,希望對大家有幫助。

備注:

1.導入了PIL庫,是處理圖片用的,很強大;

2.導入了win32庫,是判斷隱藏文件用的,我們的項目需要刪除隱藏文件,不需要的可以直接找到刪除。

3.導入send2trash庫,是把刪除的文件放進垃圾箱,而不是永久刪除,這個我只是防止刪除有用的文件而搞得,有點嚴謹了是吧,不需要的可以刪掉啊。

4.我這個腳本是Python2.7編寫的,但是在處理中文編碼的時候非常惡心,盡管最后被我解決了,這個解決的方法,我隨后會再單獨寫一篇,但是此刻我是建議大家不要用2.x版本的python 了。據說3.x的版本的已經解決了編碼的問題。希望大家聽我的建議。

#coding=utf-8 
import sys 
import os, glob 
import platform 
import win32file,win32con 
from PIL import Image 
from send2trash import send2trash 
 
reload(sys) 
sys.setdefaultencoding('utf-8') 
 
#new_width =2048 
#width =int(raw_input("the width U want:")) 
#imgslist = glob.glob(path+'/*.*') 
 
ShuiPing="水平" 
ShiZhuang="矢狀" 
GuanZhuang="冠狀" 
 
def Py_Log(_string): 
  print "----"+_string.decode('utf-8')+"----" 
 
def is_windows_system(): 
  return 'Windows' in platform.system() 
 
def is_hiden_file(file_Path):  
  if is_windows_system():  
    fileAttr = win32file.GetFileAttributes(file_Path) 
    if fileAttr & win32con.FILE_ATTRIBUTE_HIDDEN :  
      return True  
    return False  
  return False 
 
def remove_hidden_file(file_path): 
  send2trash(file_path) 
  print "Delete hidden file path:"+file_path 
 
def astrcmp(str1,str2): 
  return str1.lower()==str2.lower() 
 
def resize_image(img_path): 
  try: 
    mPath, ext = os.path.splitext(img_path) 
    if (astrcmp(ext,".png") or astrcmp(ext,".jpg")): 
      img = Image.open(img_path) 
      (width,height) = img.size 
       
      if(width != new_width): 
        new_height = int(height * new_width / width) 
        out = img.resize((new_width,new_height),Image.ANTIALIAS) 
        new_file_name = '%s%s' %(mPath,ext) 
        out.save(new_file_name,quality=100) 
        Py_Log("圖片尺寸修改為:"+str(new_width)) 
      else: 
        Py_Log("圖片尺寸正確,未修改") 
    else: 
      Py_Log("非圖片格式") 
  except Exception,e: 
    print e 
 
#改變圖片類型 
def change_img_type(img_path): 
  try: 
    img = Image.open(img_path) 
    img.save('new_type.png') 
  except Exception,e: 
    print e 
 
#處理遠程圖片 
def handle_remote_img(img_url): 
  try: 
    request = urllib2.Request(img_url) 
    img_data = urllib2.urlopen(request).read() 
    img_buffer = StringIO.StringIO(img_data) 
    img = Image.open(img_buffer) 
    img.save('remote.jpg') 
    (width,height) = img.size 
    out = img.resize((200,height * 200 / width),Image.ANTIALIAS) 
    out.save('remote_small.jpg') 
  except Exception,e: 
    print e 
 
def rename_forder(forder_path): 
  Py_Log("------------rename_forder--------------------------") 
  names = os.path.split(forder_path) 
  try: 
    if(unicode(ShuiPing) in unicode(names[1],'gbk')): 
      os.rename(forder_path,names[0]+"\\"+"01") 
      Py_Log(names[1]+"-->"+"01") 
    if(unicode(ShiZhuang) in unicode(names[1],'gbk')): 
      os.rename(forder_path,names[0]+"\\"+"02") 
      Py_Log(names[1]+"-->"+"02") 
    if(unicode(GuanZhuang) in unicode(names[1],'gbk')): 
      os.rename(forder_path,names[0]+"\\"+"03") 
      Py_Log(names[1]+"-->"+"03") 
  except Exception,e: 
    print e 
 
def BFS_Dir(dirPath, dirCallback = None, fileCallback = None): 
  queue = [] 
  ret = [] 
  queue.append(dirPath); 
  while len(queue) > 0: 
    tmp = queue.pop(0) 
    if(os.path.isdir(tmp)): 
      ret.append(tmp) 
      for item in os.listdir(tmp): 
        queue.append(os.path.join(tmp, item)) 
      if dirCallback: 
        dirCallback(tmp) 
    elif(os.path.isfile(tmp)): 
      ret.append(tmp) 
      if fileCallback: 
        fileCallback(tmp) 
  return ret 
 
def DFS_Dir(dirPath, dirCallback = None, fileCallback = None): 
  stack = [] 
  ret = [] 
  stack.append(dirPath); 
  while len(stack) > 0: 
    tmp = stack.pop(len(stack) - 1) 
    if(os.path.isdir(tmp)): 
      ret.append(tmp) 
      for item in os.listdir(tmp): 
        stack.append(os.path.join(tmp, item)) 
      if dirCallback: 
        dirCallback(tmp) 
    elif(os.path.isfile(tmp)): 
      ret.append(tmp) 
      if fileCallback: 
        fileCallback(tmp) 
  return ret 
 
def printDir(dirPath): 
  print "dir: " + dirPath 
  if(is_hiden_file(dirPath)): 
    remove_hidden_file(dirPath) 
  else: 
    rename_forder(dirPath) 
 
def printFile(dirPath): 
  print "file: " + dirPath 
  resize_image(dirPath) 
  return True 
 
 
if __name__ == '__main__': 
  while True: 
    path = raw_input("Path:") 
    new_width =int(raw_input("the width U want:")) 
    try: 
      b = BFS_Dir(path , printDir, printFile) 
      Py_Log ("\r\n   **********\r\n"+"*********圖片處理完畢*********"+"\r\n  **********\r\n") 
    except: 
      print "Unexpected error:", sys.exc_info() 
    raw_input('press enter key to rehandle') 

文章標題:python實現批量修改圖片格式和尺寸-創新互聯
文章出自:http://m.kartarina.com/article36/ccijpg.html

成都網站建設公司_創新互聯,為您提供微信小程序域名注冊微信公眾號全網營銷推廣自適應網站網站策劃

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

成都定制網站建設
主站蜘蛛池模板: 无码人妻丰满熟妇区毛片| 成人免费无码大片A毛片抽搐 | 曰批全过程免费视频在线观看无码 | 特级无码毛片免费视频尤物| 亚洲AV无码欧洲AV无码网站| 亚洲AV综合色区无码一二三区| 中文字幕人妻无码专区| 在线精品自偷自拍无码中文| 国产在线精品无码二区二区| 亚洲精品~无码抽插| 亚洲AV无码国产剧情| 午夜不卡无码中文字幕影院| 中文无码喷潮在线播放| 国产午夜av无码无片久久96| 日韩人妻无码一区二区三区久久| 亚洲AV中文无码乱人伦在线视色| 亚洲国产av高清无码| 亚洲AV无码码潮喷在线观看| 国产成人无码精品久久久露脸| 亚洲一区二区三区无码国产 | 无码精品人妻一区二区三区免费看| 性虎精品无码AV导航| 98久久人妻无码精品系列蜜桃 | 国产午夜av无码无片久久96| 久久久久亚洲AV无码永不| 东京热人妻无码一区二区av| 亚洲国产91精品无码专区| 亚洲av无码成人影院一区| 人妻少妇偷人精品无码| 亚洲AV无码国产在丝袜线观看| 国产成人亚洲综合无码| 精品无码专区亚洲| 成人无码Av片在线观看| 免费人成无码大片在线观看 | 中文无码制服丝袜人妻av| 亚洲精品97久久中文字幕无码| 亚洲国产精品无码久久久久久曰| 国产精品无码无卡无需播放器| 精品无码成人久久久久久| 无码国产精品久久一区免费| 精品久久久无码人妻中文字幕豆芽 |