基于Python實(shí)現(xiàn)圖片格式批量轉(zhuǎn)換器
開發(fā)環(huán)境準(zhǔn)備
Python 3.6+
Pillow庫 (PIL的fork版本)
安裝Pillow庫:
pip install pillow
核心功能
支持多種常見圖片格式之間的轉(zhuǎn)換(JPG, PNG, BMP, GIF, TIFF等)
批量處理指定文件夾中的所有圖片
可選擇保留原始圖片或僅保留轉(zhuǎn)換后的圖片
支持調(diào)整圖片質(zhì)量和大小
簡單的命令行界面和圖形用戶界面(GUI)兩種使用方式
技術(shù)要點(diǎn)
1. Pillow庫基礎(chǔ)
Pillow是Python圖像處理庫(PIL)的一個分支,提供了豐富的圖像處理功能。主要用到的模塊:
- Image: 圖像對象的創(chuàng)建、讀取和保存
- ImageOps: 圖像操作,如調(diào)整大小、翻轉(zhuǎn)等
- ImageEnhance: 圖像增強(qiáng),如亮度、對比度調(diào)整
2. 文件系統(tǒng)操作
使用os和pathlib模塊處理文件路徑
遞歸遍歷目錄
文件類型判斷
3. 用戶界面
命令行參數(shù)解析
簡單GUI界面構(gòu)建(使用tkinter)
代碼實(shí)現(xiàn)與解析
1. 導(dǎo)入必要的庫
from PIL import Image import os import sys import argparse from pathlib import Path import tkinter as tk from tkinter import filedialog, messagebox, ttk
知識點(diǎn):
PIL.Image: Pillow的核心模塊,用于圖像處理
os和pathlib: 文件系統(tǒng)操作
argparse: 命令行參數(shù)解析
tkinter: Python標(biāo)準(zhǔn)GUI庫
2. 圖片格式轉(zhuǎn)換核心函數(shù)
def convert_image(input_path, output_path, format, quality=95, resize=None): """ 轉(zhuǎn)換單個圖片的格式 參數(shù): input_path - 輸入圖片路徑 output_path - 輸出圖片路徑 format - 目標(biāo)格式 (如 'JPEG', 'PNG') quality - 圖片質(zhì)量 (1-100, 僅對JPEG格式有效) resize - 調(diào)整大小的元組 (width, height) 或 None 返回: bool - 轉(zhuǎn)換是否成功 """ try: # 打開圖片 img = Image.open(input_path) # 如果是RGBA模式且轉(zhuǎn)換為JPEG,需要轉(zhuǎn)換為RGB模式 if img.mode == 'RGBA' and format.upper() == 'JPEG': img = img.convert('RGB') # 調(diào)整大小 if resize: img = img.resize(resize, Image.LANCZOS) # 保存轉(zhuǎn)換后的圖片 if format.upper() == 'JPEG': img.save(output_path, format=format, quality=quality) else: img.save(output_path, format=format) return True except Exception as e: print(f"轉(zhuǎn)換圖片 {input_path} 時(shí)出錯: {e}") return False
知識點(diǎn):
Image.open(): 打開圖片文件
圖像模式轉(zhuǎn)換: RGBA轉(zhuǎn)RGB(JPEG不支持透明通道)
Image.LANCZOS: 高質(zhì)量的圖像縮放算法
異常處理: 捕獲并處理可能的錯誤
3. 批量轉(zhuǎn)換功能
def batch_convert(input_dir, output_dir, target_format, quality=95, resize=None, recursive=False, keep_original=True): """ 批量轉(zhuǎn)換指定目錄中的圖片 參數(shù): input_dir - 輸入目錄 output_dir - 輸出目錄 target_format - 目標(biāo)格式 quality - 圖片質(zhì)量 resize - 調(diào)整大小的元組 recursive - 是否遞歸處理子目錄 keep_original - 是否保留原始圖片 返回: tuple - (成功數(shù)量, 失敗數(shù)量) """ # 支持的圖片格式 supported_formats = ['.jpg', '.jpeg', '.png', '.bmp', '.gif', '.tiff'] # 創(chuàng)建輸出目錄 os.makedirs(output_dir, exist_ok=True) success_count = 0 failed_count = 0 # 遍歷目錄 for root, dirs, files in os.walk(input_dir): # 如果不遞歸處理子目錄且不是根目錄,則跳過 if not recursive and root != input_dir: continue # 創(chuàng)建對應(yīng)的輸出子目錄 rel_path = os.path.relpath(root, input_dir) if rel_path != '.': current_output_dir = os.path.join(output_dir, rel_path) os.makedirs(current_output_dir, exist_ok=True) else: current_output_dir = output_dir # 處理文件 for file in files: # 檢查文件擴(kuò)展名 ext = os.path.splitext(file)[1].lower() if ext not in supported_formats: continue # 構(gòu)建輸入和輸出路徑 input_path = os.path.join(root, file) output_filename = os.path.splitext(file)[0] + '.' + target_format.lower() output_path = os.path.join(current_output_dir, output_filename) # 轉(zhuǎn)換圖片 if convert_image(input_path, output_path, target_format, quality, resize): success_count += 1 # 如果不保留原始圖片且不是在原目錄操作,則刪除原始圖片 if not keep_original and input_dir != output_dir: try: os.remove(input_path) except: pass else: failed_count += 1 return (success_count, failed_count)
知識點(diǎn):
os.walk(): 遞歸遍歷目錄
os.path.relpath(): 獲取相對路徑
os.makedirs(): 創(chuàng)建多級目錄
文件擴(kuò)展名處理: 使用os.path.splitext()分離文件名和擴(kuò)展名
4. 命令行界面
def setup_cli(): """設(shè)置命令行參數(shù)解析器""" parser = argparse.ArgumentParser(description='批量轉(zhuǎn)換圖片格式') parser.add_argument('input', help='輸入目錄或文件') parser.add_argument('output', help='輸出目錄') parser.add_argument('format', help='目標(biāo)格式 (如: jpg, png, bmp)') parser.add_argument('-q', '--quality', type=int, default=95, help='圖片質(zhì)量 (1-100, 默認(rèn): 95)') parser.add_argument('-r', '--recursive', action='store_true', help='遞歸處理子目錄') parser.add_argument('-k', '--keep', action='store_true', help='保留原始圖片') parser.add_argument('--resize', nargs=2, type=int, metavar=('WIDTH', 'HEIGHT'), help='調(diào)整圖片大小') return parser.parse_args()
知識點(diǎn):
argparse: 命令行參數(shù)解析
參數(shù)類型: 位置參數(shù)、可選參數(shù)、標(biāo)志參數(shù)
參數(shù)類型轉(zhuǎn)換: 使用type=int將字符串轉(zhuǎn)換為整數(shù)
5. 圖形用戶界面
class ImageConverterGUI: def __init__(self, root): self.root = root self.root.title("圖片格式批量轉(zhuǎn)換器") self.root.geometry("600x450") self.root.resizable(True, True) # 創(chuàng)建主框架 main_frame = ttk.Frame(root, padding="10") main_frame.pack(fill=tk.BOTH, expand=True) # 輸入目錄 ttk.Label(main_frame, text="輸入目錄:").grid(column=0, row=0, sticky=tk.W, pady=5) self.input_dir = tk.StringVar() ttk.Entry(main_frame, width=50, textvariable=self.input_dir).grid(column=1, row=0, pady=5) ttk.Button(main_frame, text="瀏覽...", command=self.browse_input).grid(column=2, row=0, padx=5, pady=5) # 輸出目錄 ttk.Label(main_frame, text="輸出目錄:").grid(column=0, row=1, sticky=tk.W, pady=5) self.output_dir = tk.StringVar() ttk.Entry(main_frame, width=50, textvariable=self.output_dir).grid(column=1, row=1, pady=5) ttk.Button(main_frame, text="瀏覽...", command=self.browse_output).grid(column=2, row=1, padx=5, pady=5) # 目標(biāo)格式 ttk.Label(main_frame, text="目標(biāo)格式:").grid(column=0, row=2, sticky=tk.W, pady=5) self.format_var = tk.StringVar(value="JPEG") formats = ["JPEG", "PNG", "BMP", "GIF", "TIFF"] ttk.Combobox(main_frame, textvariable=self.format_var, values=formats, width=10).grid(column=1, row=2, sticky=tk.W, pady=5) # 圖片質(zhì)量 ttk.Label(main_frame, text="圖片質(zhì)量:").grid(column=0, row=3, sticky=tk.W, pady=5) self.quality_var = tk.IntVar(value=95) quality_frame = ttk.Frame(main_frame) quality_frame.grid(column=1, row=3, sticky=tk.W, pady=5) ttk.Scale(quality_frame, from_=1, to=100, variable=self.quality_var, orient=tk.HORIZONTAL, length=200).pack(side=tk.LEFT) ttk.Label(quality_frame, textvariable=self.quality_var).pack(side=tk.LEFT, padx=5) # 調(diào)整大小 ttk.Label(main_frame, text="調(diào)整大小:").grid(column=0, row=4, sticky=tk.W, pady=5) resize_frame = ttk.Frame(main_frame) resize_frame.grid(column=1, row=4, sticky=tk.W, pady=5) self.resize_enabled = tk.BooleanVar(value=False) ttk.Checkbutton(resize_frame, text="啟用", variable=self.resize_enabled).pack(side=tk.LEFT) ttk.Label(resize_frame, text="寬:").pack(side=tk.LEFT, padx=(10, 0)) self.width_var = tk.IntVar(value=800) ttk.Entry(resize_frame, width=5, textvariable=self.width_var).pack(side=tk.LEFT, padx=(0, 5)) ttk.Label(resize_frame, text="高:").pack(side=tk.LEFT) self.height_var = tk.IntVar(value=600) ttk.Entry(resize_frame, width=5, textvariable=self.height_var).pack(side=tk.LEFT) # 遞歸處理 self.recursive_var = tk.BooleanVar(value=False) ttk.Checkbutton(main_frame, text="遞歸處理子目錄", variable=self.recursive_var).grid(column=1, row=5, sticky=tk.W, pady=5) # 保留原始圖片 self.keep_original_var = tk.BooleanVar(value=True) ttk.Checkbutton(main_frame, text="保留原始圖片", variable=self.keep_original_var).grid(column=1, row=6, sticky=tk.W, pady=5) # 轉(zhuǎn)換按鈕 ttk.Button(main_frame, text="開始轉(zhuǎn)換", command=self.start_conversion).grid(column=1, row=7, pady=10) # 進(jìn)度條 self.progress_var = tk.DoubleVar() ttk.Progressbar(main_frame, variable=self.progress_var, maximum=100).grid(column=0, row=8, columnspan=3, sticky=(tk.W, tk.E), pady=5) # 狀態(tài)標(biāo)簽 self.status_var = tk.StringVar(value="就緒") ttk.Label(main_frame, textvariable=self.status_var).grid(column=0, row=9, columnspan=3, sticky=tk.W, pady=5) def browse_input(self): directory = filedialog.askdirectory() if directory: self.input_dir.set(directory) def browse_output(self): directory = filedialog.askdirectory() if directory: self.output_dir.set(directory) def start_conversion(self): input_dir = self.input_dir.get() output_dir = self.output_dir.get() target_format = self.format_var.get() quality = self.quality_var.get() recursive = self.recursive_var.get() keep_original = self.keep_original_var.get() # 檢查輸入 if not input_dir or not output_dir: messagebox.showerror("錯誤", "請指定輸入和輸出目錄") return # 檢查調(diào)整大小參數(shù) resize = None if self.resize_enabled.get(): try: width = self.width_var.get() height = self.height_var.get() if width <= 0 or height <= 0: raise ValueError("寬度和高度必須大于0") resize = (width, height) except: messagebox.showerror("錯誤", "調(diào)整大小參數(shù)無效") return # 開始轉(zhuǎn)換 self.status_var.set("轉(zhuǎn)換中...") self.root.update() try: success, failed = batch_convert( input_dir, output_dir, target_format, quality, resize, recursive, keep_original ) self.status_var.set(f"轉(zhuǎn)換完成。成功: {success}, 失敗: {failed}") messagebox.showinfo("完成", f"轉(zhuǎn)換完成\n成功: {success}\n失敗: {failed}") except Exception as e: self.status_var.set(f"轉(zhuǎn)換出錯: {str(e)}") messagebox.showerror("錯誤", f"轉(zhuǎn)換過程中出錯:\n{str(e)}")
知識點(diǎn):
tkinter: Python標(biāo)準(zhǔn)GUI庫
布局管理: 使用grid布局
控件使用: 標(biāo)簽、輸入框、按鈕、復(fù)選框、組合框、進(jìn)度條等
事件處理: 按鈕點(diǎn)擊事件
文件對話框: 使用filedialog選擇目錄
6. 主函數(shù)
def main(): # 檢查是否有命令行參數(shù) if len(sys.argv) > 1: # 命令行模式 args = setup_cli() # 檢查輸入和輸出目錄 if not os.path.exists(args.input): print(f"錯誤: 輸入路徑 '{args.input}' 不存在") return # 調(diào)整大小參數(shù) resize = tuple(args.resize) if args.resize else None # 開始轉(zhuǎn)換 print(f"開始轉(zhuǎn)換圖片從 {args.input} 到 {args.output},格式: {args.format}") success, failed = batch_convert( args.input, args.output, args.format.upper(), args.quality, resize, args.recursive, args.keep ) print(f"轉(zhuǎn)換完成。成功: {success}, 失敗: {failed}") else: # GUI模式 root = tk.Tk() app = ImageConverterGUI(root) root.mainloop() ???????if __name__ == "__main__": main()
完整代碼
#!/usr/bin/env python # -*- coding: utf-8 -*- """ 圖片格式批量轉(zhuǎn)換器 功能: 批量將圖片從一種格式轉(zhuǎn)換為另一種格式,支持調(diào)整大小和質(zhì)量 作者: Python開發(fā)者 """ from PIL import Image import os import sys import argparse from pathlib import Path import tkinter as tk from tkinter import filedialog, messagebox, ttk def convert_image(input_path, output_path, format, quality=95, resize=None): """ 轉(zhuǎn)換單個圖片的格式 參數(shù): input_path - 輸入圖片路徑 output_path - 輸出圖片路徑 format - 目標(biāo)格式 (如 'JPEG', 'PNG') quality - 圖片質(zhì)量 (1-100, 僅對JPEG格式有效) resize - 調(diào)整大小的元組 (width, height) 或 None 返回: bool - 轉(zhuǎn)換是否成功 """ try: # 打開圖片 img = Image.open(input_path) # 如果是RGBA模式且轉(zhuǎn)換為JPEG,需要轉(zhuǎn)換為RGB模式 if img.mode == 'RGBA' and format.upper() == 'JPEG': img = img.convert('RGB') # 調(diào)整大小 if resize: img = img.resize(resize, Image.LANCZOS) # 保存轉(zhuǎn)換后的圖片 if format.upper() == 'JPEG': img.save(output_path, format=format, quality=quality) else: img.save(output_path, format=format) return True except Exception as e: print(f"轉(zhuǎn)換圖片 {input_path} 時(shí)出錯: {e}") return False def batch_convert(input_dir, output_dir, target_format, quality=95, resize=None, recursive=False, keep_original=True): """ 批量轉(zhuǎn)換指定目錄中的圖片 參數(shù): input_dir - 輸入目錄 output_dir - 輸出目錄 target_format - 目標(biāo)格式 quality - 圖片質(zhì)量 resize - 調(diào)整大小的元組 recursive - 是否遞歸處理子目錄 keep_original - 是否保留原始圖片 返回: tuple - (成功數(shù)量, 失敗數(shù)量) """ # 支持的圖片格式 supported_formats = ['.jpg', '.jpeg', '.png', '.bmp', '.gif', '.tiff'] # 創(chuàng)建輸出目錄 os.makedirs(output_dir, exist_ok=True) success_count = 0 failed_count = 0 # 遍歷目錄 for root, dirs, files in os.walk(input_dir): # 如果不遞歸處理子目錄且不是根目錄,則跳過 if not recursive and root != input_dir: continue # 創(chuàng)建對應(yīng)的輸出子目錄 rel_path = os.path.relpath(root, input_dir) if rel_path != '.': current_output_dir = os.path.join(output_dir, rel_path) os.makedirs(current_output_dir, exist_ok=True) else: current_output_dir = output_dir # 處理文件 for file in files: # 檢查文件擴(kuò)展名 ext = os.path.splitext(file)[1].lower() if ext not in supported_formats: continue # 構(gòu)建輸入和輸出路徑 input_path = os.path.join(root, file) output_filename = os.path.splitext(file)[0] + '.' + target_format.lower() output_path = os.path.join(current_output_dir, output_filename) # 轉(zhuǎn)換圖片 if convert_image(input_path, output_path, target_format, quality, resize): success_count += 1 # 如果不保留原始圖片且不是在原目錄操作,則刪除原始圖片 if not keep_original and input_dir != output_dir: try: os.remove(input_path) except: pass else: failed_count += 1 return (success_count, failed_count) def setup_cli(): """設(shè)置命令行參數(shù)解析器""" parser = argparse.ArgumentParser(description='批量轉(zhuǎn)換圖片格式') parser.add_argument('input', help='輸入目錄或文件') parser.add_argument('output', help='輸出目錄') parser.add_argument('format', help='目標(biāo)格式 (如: jpg, png, bmp)') parser.add_argument('-q', '--quality', type=int, default=95, help='圖片質(zhì)量 (1-100, 默認(rèn): 95)') parser.add_argument('-r', '--recursive', action='store_true', help='遞歸處理子目錄') parser.add_argument('-k', '--keep', action='store_true', help='保留原始圖片') parser.add_argument('--resize', nargs=2, type=int, metavar=('WIDTH', 'HEIGHT'), help='調(diào)整圖片大小') return parser.parse_args() class ImageConverterGUI: def __init__(self, root): self.root = root self.root.title("圖片格式批量轉(zhuǎn)換器") self.root.geometry("600x450") self.root.resizable(True, True) # 創(chuàng)建主框架 main_frame = ttk.Frame(root, padding="10") main_frame.pack(fill=tk.BOTH, expand=True) # 輸入目錄 ttk.Label(main_frame, text="輸入目錄:").grid(column=0, row=0, sticky=tk.W, pady=5) self.input_dir = tk.StringVar() ttk.Entry(main_frame, width=50, textvariable=self.input_dir).grid(column=1, row=0, pady=5) ttk.Button(main_frame, text="瀏覽...", command=self.browse_input).grid(column=2, row=0, padx=5, pady=5) # 輸出目錄 ttk.Label(main_frame, text="輸出目錄:").grid(column=0, row=1, sticky=tk.W, pady=5) self.output_dir = tk.StringVar() ttk.Entry(main_frame, width=50, textvariable=self.output_dir).grid(column=1, row=1, pady=5) ttk.Button(main_frame, text="瀏覽...", command=self.browse_output).grid(column=2, row=1, padx=5, pady=5) # 目標(biāo)格式 ttk.Label(main_frame, text="目標(biāo)格式:").grid(column=0, row=2, sticky=tk.W, pady=5) self.format_var = tk.StringVar(value="JPEG") formats = ["JPEG", "PNG", "BMP", "GIF", "TIFF"] ttk.Combobox(main_frame, textvariable=self.format_var, values=formats, width=10).grid(column=1, row=2, sticky=tk.W, pady=5) # 圖片質(zhì)量 ttk.Label(main_frame, text="圖片質(zhì)量:").grid(column=0, row=3, sticky=tk.W, pady=5) self.quality_var = tk.IntVar(value=95) quality_frame = ttk.Frame(main_frame) quality_frame.grid(column=1, row=3, sticky=tk.W, pady=5) ttk.Scale(quality_frame, from_=1, to=100, variable=self.quality_var, orient=tk.HORIZONTAL, length=200).pack( side=tk.LEFT) ttk.Label(quality_frame, textvariable=self.quality_var).pack(side=tk.LEFT, padx=5) # 調(diào)整大小 ttk.Label(main_frame, text="調(diào)整大小:").grid(column=0, row=4, sticky=tk.W, pady=5) resize_frame = ttk.Frame(main_frame) resize_frame.grid(column=1, row=4, sticky=tk.W, pady=5) self.resize_enabled = tk.BooleanVar(value=False) ttk.Checkbutton(resize_frame, text="啟用", variable=self.resize_enabled).pack(side=tk.LEFT) ttk.Label(resize_frame, text="寬:").pack(side=tk.LEFT, padx=(10, 0)) self.width_var = tk.IntVar(value=800) ttk.Entry(resize_frame, width=5, textvariable=self.width_var).pack(side=tk.LEFT, padx=(0, 5)) ttk.Label(resize_frame, text="高:").pack(side=tk.LEFT) self.height_var = tk.IntVar(value=600) ttk.Entry(resize_frame, width=5, textvariable=self.height_var).pack(side=tk.LEFT) # 遞歸處理 self.recursive_var = tk.BooleanVar(value=False) ttk.Checkbutton(main_frame, text="遞歸處理子目錄", variable=self.recursive_var).grid(column=1, row=5, sticky=tk.W, pady=5) # 保留原始圖片 self.keep_original_var = tk.BooleanVar(value=True) ttk.Checkbutton(main_frame, text="保留原始圖片", variable=self.keep_original_var).grid(column=1, row=6, sticky=tk.W, pady=5) # 轉(zhuǎn)換按鈕 ttk.Button(main_frame, text="開始轉(zhuǎn)換", command=self.start_conversion).grid(column=1, row=7, pady=10) # 進(jìn)度條 self.progress_var = tk.DoubleVar() ttk.Progressbar(main_frame, variable=self.progress_var, maximum=100).grid(column=0, row=8, columnspan=3, sticky=(tk.W, tk.E), pady=5) # 狀態(tài)標(biāo)簽 self.status_var = tk.StringVar(value="就緒") ttk.Label(main_frame, textvariable=self.status_var).grid(column=0, row=9, columnspan=3, sticky=tk.W, pady=5) def browse_input(self): directory = filedialog.askdirectory() if directory: self.input_dir.set(directory) def browse_output(self): directory = filedialog.askdirectory() if directory: self.output_dir.set(directory) def start_conversion(self): input_dir = self.input_dir.get() output_dir = self.output_dir.get() target_format = self.format_var.get() quality = self.quality_var.get() recursive = self.recursive_var.get() keep_original = self.keep_original_var.get() # 檢查輸入 if not input_dir or not output_dir: messagebox.showerror("錯誤", "請指定輸入和輸出目錄") return # 檢查調(diào)整大小參數(shù) resize = None if self.resize_enabled.get(): try: width = self.width_var.get() height = self.height_var.get() if width <= 0 or height <= 0: raise ValueError("寬度和高度必須大于0") resize = (width, height) except: messagebox.showerror("錯誤", "調(diào)整大小參數(shù)無效") return # 開始轉(zhuǎn)換 self.status_var.set("轉(zhuǎn)換中...") self.root.update() try: success, failed = batch_convert( input_dir, output_dir, target_format, quality, resize, recursive, keep_original ) self.status_var.set(f"轉(zhuǎn)換完成。成功: {success}, 失敗: {failed}") messagebox.showinfo("完成", f"轉(zhuǎn)換完成\n成功: {success}\n失敗: {failed}") except Exception as e: self.status_var.set(f"轉(zhuǎn)換出錯: {str(e)}") messagebox.showerror("錯誤", f"轉(zhuǎn)換過程中出錯:\n{str(e)}") def main(): # 檢查是否有命令行參數(shù) if len(sys.argv) > 1: # 命令行模式 args = setup_cli() # 檢查輸入和輸出目錄 if not os.path.exists(args.input): print(f"錯誤: 輸入路徑 '{args.input}' 不存在") return # 調(diào)整大小參數(shù) resize = tuple(args.resize) if args.resize else None # 開始轉(zhuǎn)換 print(f"開始轉(zhuǎn)換圖片從 {args.input} 到 {args.output},格式: {args.format}") success, failed = batch_convert( args.input, args.output, args.format.upper(), args.quality, resize, args.recursive, args.keep ) print(f"轉(zhuǎn)換完成。成功: {success}, 失敗: {failed}") else: # GUI模式 root = tk.Tk() app = ImageConverterGUI(root) root.mainloop() if __name__ == "__main__": main()
知識點(diǎn):
命令行模式和GUI模式的切換
sys.argv: 獲取命令行參數(shù)
tkinter主循環(huán): root.mainloop()
使用方法
命令行方式
# 基本用法 python image_converter.py 輸入目錄 輸出目錄 目標(biāo)格式 # 示例: 將input_folder中的圖片轉(zhuǎn)換為PNG格式并保存到output_folder python image_converter.py input_folder output_folder png # 高級用法 python image_converter.py input_folder output_folder jpg -q 85 -r --resize 800 600
GUI方式
直接運(yùn)行程序,不帶任何參數(shù):
python image_converter.py
然后在圖形界面中:
- 選擇輸入目錄
- 選擇輸出目錄
- 設(shè)置目標(biāo)格式和其他選項(xiàng)
- 點(diǎn)擊"開始轉(zhuǎn)換"按鈕
進(jìn)階知識點(diǎn)
1. 圖像處理基礎(chǔ)
像素: 圖像的基本單位
顏色模式: RGB, RGBA, CMYK, 灰度等
圖像格式特點(diǎn):
- JPEG: 有損壓縮,不支持透明度,適合照片
- PNG: 無損壓縮,支持透明度,適合圖標(biāo)和截圖
- GIF: 支持動畫,有限的顏色數(shù)量
- BMP: 無壓縮,文件較大
- TIFF: 高質(zhì)量,支持多頁,常用于專業(yè)印刷
2. Pillow高級特性
- 圖像增強(qiáng): 亮度、對比度、銳化等調(diào)整
- 濾鏡效果: 模糊、銳化、邊緣檢測等
- 圖像合成: 圖層混合、水印等
- 批處理: 多進(jìn)程處理提高效率
3. 性能優(yōu)化
- 使用生成器減少內(nèi)存占用
- 多線程/多進(jìn)程處理提高轉(zhuǎn)換速度
- 縮略圖生成優(yōu)化
可擴(kuò)展功能
批量水印添加:為圖片添加文字或圖片水印
圖片批量裁剪:自動裁剪圖片到指定比例或尺寸
批量圖片優(yōu)化:自動調(diào)整亮度、對比度和圖片銳化
批量重命名:根據(jù)規(guī)則批量重命名圖片文件
元數(shù)據(jù)處理:保留或清除EXIF信息
到此這篇關(guān)于基于Python實(shí)現(xiàn)圖片格式批量轉(zhuǎn)換器的文章就介紹到這了,更多相關(guān)Python圖片格式轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python調(diào)用百度AI實(shí)現(xiàn)人像分割詳解
本文主要介紹了如何通過Python調(diào)用百度AI從而實(shí)現(xiàn)人像的分割與合成,文中的示例代碼對我們的工作或?qū)W習(xí)有一定的幫助,需要的朋友可以參考一下2021-12-12python多進(jìn)程實(shí)現(xiàn)進(jìn)程間通信實(shí)例
這篇文章主要介紹了python多進(jìn)程實(shí)現(xiàn)進(jìn)程間通信實(shí)例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11Python的凈值數(shù)據(jù)接口調(diào)用示例分享
這篇文章主要介紹了Python的凈值數(shù)據(jù)接口調(diào)用示例分享的相關(guān)資料,需要的朋友可以參考下2016-03-03