《自拍教程71》Python mediainfo批量重命名圖片文件

来源:https://www.cnblogs.com/zipython/archive/2020/06/17/13154696.html
-Advertisement-
Play Games

案例故事: 大部分帶彩色屏幕的終端設備,不管是手機,車機,電視等等,都需要涉及圖片的顯示, 作為一名專業的多媒體測試人員,我們需要一堆的規範化標準的的圖片測試文件, 但是發現圖片資源名字命名的很隨意比如:IMG_20200325_161111.jpg, 以上命名不能看出圖片文件的具體圖片編碼格式,分 ...


案例故事: 大部分帶彩色屏幕的終端設備,不管是手機,車機,電視等等,都需要涉及圖片的顯示,
作為一名專業的多媒體測試人員,我們需要一堆的規範化標準的的圖片測試文件
但是發現圖片資源名字命名的很隨意比如:IMG_20200325_161111.jpg,
以上命名不能看出圖片文件的具體圖片編碼格式,解析度等信息,
測試經理要求我進行批量重命名工作,模板如下,
圖片編碼格式_解析度_位深度_容器.容器, 例如:
JPEG_1920x1080_32bit_jpg.jpg


圖片編解碼基本知識

圖片編碼:將某各風景畫面取景轉成圖片數據文件的過程,取景肯定涉及取景的範圍,
圖片解碼:將圖片數據文件顯示到屏幕上的過程。

主要涉及以下技術參數:

圖片技術參數 參數釋義 舉例
圖片編碼格式
(壓縮技術)
即像素點壓縮的一類技術,
不同的編碼格式,
其壓縮率與壓縮效果不一樣。
JPEG, PNG, GIF, BMP, Webp, RAW, Heic
圖片解析度
(單位:Pixel)
圖片長像素點的數量*圖片寬像素點的數量 4096×2160(4K), 1920x1080,
1280x720,720×480,
640x480, 320x480等
甚至10億像素的圖片都存在的。
位深度
(單位:bit)
每個像素點所包含的數據量的大小 8bit, 16bit, 32bit
圖片容器 文件尾碼,將圖片像素點封裝的一種文件格式 .jpg; .png; .gif; .bmp; .heic; .webp等

我們碰到的任何圖片文件,都是數據的集合,
一般數據越大,其圖片越清晰。



準備階段
  1. 確保mediainfo.exe 命令行工具已經加入環境變數,查看其具體功能方法
  2. 以下是某個圖片文件的mediainfo信息, 都是文本,Python處理起來肯定很簡單的。
  3. 如果要進行批量重命名圖片,我們還是用輸入輸出文件架構,如下:

	+---Input_Image   #批量放入待命名的圖片文件
	|       1.jpg
	|       2.png
	|       
	+---Output_Image   #批量輸出已命名的圖片文件
	|       JPEG_1920x1080_32bit_jpg.jpg
	|	    PNG_1280x720_32bit_png.png
	|
    \image_info.py   # 獲取圖片文件info信息的模塊,
	\rename_image.py  #調用image_info.py並實現重名,可雙擊運行


定義image_info.py模塊

由於涉及較複雜的代碼,建議直接用面向對象類的編程方式實現:

# coding=utf-8

import os
import re
import subprocess


class ImageInfoGetter():
    '''獲取圖片文件的Formate, 解析度,位深度'''

    def __init__(self, image_file):
        '''判斷文件是否存在,如果存在獲取其mediainfo信息'''
        if os.path.exists(image_file):
            self.image_file = image_file
            p_obj = subprocess.Popen('mediainfo "%s"' % self.image_file, shell=True, stdout=subprocess.PIPE,
                                     stderr=subprocess.PIPE)
            self.info = p_obj.stdout.read().decode("utf-8")  # 解決非英文字元的編碼問題
        else:
            raise FileNotFoundError("Not this File!")  # 如果多媒體文件路徑不存在,必須中斷

    def get_image_format(self):
        '''獲取圖片的格式,比如JPEG, PNG, BMP等'''
        try:
            image_codec = re.findall(r"Format\s+:\s(.*)", self.info)[-1]  # 取第最後一個Format欄位
            image_codec = image_codec.strip()  # 去除前後的空格
        except:
            image_codec = "undef"  # 防止程式因為異常而中斷
        return image_codec

    def get_image_resolution(self):
        '''獲取圖片的解析度'''
        try:
            image_widget = re.findall(r'Width\s+:\s(.*)pixels', self.info)[-1]
            image_widget = image_widget.replace(" ", "")
            image_height = re.findall(r'Height\s+:\s(.*)pixels', self.info)[-1]
            image_height = image_height.replace(" ", "")
            image_resolution = image_widget + "x" + image_height
        except:
            image_resolution = "undef"  # 防止程式因為異常而中斷
        return image_resolution

    def get_image_bit_depth(self):
        '''獲取圖片的位深度'''
        try:
            image_bit_depth = re.findall(r"Bit depth\s+:\s(.*bit)s", self.info)[-1].strip()
            image_bit_depth = image_bit_depth.replace(" ", "")  # 去空格
        except:
            image_bit_depth = "undef"  # 防止程式因為異常而中斷
        return image_bit_depth

    def get_image_container(self):
        '''獲取圖片容器,即文件尾碼名'''
        _, image_container = os.path.splitext(self.image_file)
        if not image_container:
            raise NameError("This file no extension")
        image_container = image_container.replace(".", "")
        image_container = image_container.lower() # 全部轉成小寫
        return image_container


if __name__ == '__main__':
    # 以下代碼塊,只是用來測試本模塊的,一般不建議直接在這裡大面積調用本模塊'''
    i_obj = ImageInfoGetter("C:\\img.jpg")
    image_format = i_obj.get_image_format()
    print(image_format)
    image_resolution = i_obj.get_image_resolution()
    print(image_resolution)
    image_bit_depth = i_obj.get_image_bit_depth()
    print(image_bit_depth)
    image_container = i_obj.get_image_container()
    print(image_container)

調用image_info.py模塊並實現批量重命名
# coding=utf-8

import os
import image_info
from shutil import copyfile

curdir = os.getcwd()

# 輸入文件夾,放入待重命名的圖片
input_image_path = os.path.join(curdir, "Input_Image")
filelist = os.listdir(input_image_path)  # 獲取文件列表

# 輸出文件夾,已命名的圖片存放在這裡
output_image_path = os.path.join(curdir, "Output_Image")

# 如果沒有Output_Image這個文件夾,則創建這個文件夾
if not os.path.exists(output_image_path):
    os.mkdir(output_image_path)

if filelist:  # 如果文件列表不為空
    for i in filelist:  # 變數文件列表
        # 以下代碼塊,只是用來測試本模塊的,一般不建議直接在這裡大面積調用本模塊'''
        image_file = os.path.join(input_image_path, i)
        i_obj = image_info.ImageInfoGetter(image_file)
        image_format = i_obj.get_image_format()
        image_resolution = i_obj.get_image_resolution()
        image_bit_depth = i_obj.get_image_bit_depth()
        image_container = i_obj.get_image_container()
        new_image_name = image_format + "_" + image_resolution + "_" + image_bit_depth + "_" \
                         + image_container + "." + image_container
        print(new_image_name)
        new_image_file = os.path.join(output_image_path, new_image_name)
        copyfile(image_file, new_image_file)  # 複製文件
else:
    print("It's a Empty folder, please input the image files which need to be renamed firstly!!!")
os.system("pause")

本案例練手素材下載

包含:mediainfo.exe(更建議丟到某個環境變數里去),
各種編碼格式的圖片文件,image_info.py模塊,rename_image.py批處理腳本
跳轉到自拍教程官網下載
運行效果如下:

以上可以看出,輸入輸出文件架構的好處,
我只需要將不同名字不同字元的,待重命名的圖片文件整理好,
丟到Input_Image文件夾下,運行程式腳本後查看Output_Image輸出文件,
就可以測試腳本的運行是否正常,健壯性(容錯)是否符合要求,
從而對這個程式腳本實現了“灰盒測試”。

小提示:比如Android手機,Google推出了CDD(Compatibiltiy Definition Document相容性定義文檔)
其第5部分,涉及了很多圖片編解碼格式的規定:

這就是Android最主要的圖片多媒體編解碼測試需求。

更多更好的原創文章,請訪問官方網站:www.zipython.com
自拍教程(自動化測試Python教程,武散人編著)
原文鏈接:https://www.zipython.com/#/detail?id=83bc5c1566104f5da17baa22f25390b6
也可關註“武散人”微信訂閱號,隨時接受文章推送。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 結合一些文章閱讀源碼後整理的Java容器常見知識點。對於一些代碼細節,本文不展開來講,有興趣可以自行閱讀參考文獻。 ...
  • 一、不同輸出格式會有不同的結果 1.%ld 用於long類型的值,如果系統中int和long大小相同,使用%d就可以,這樣的程式被移植到其他系統(int和long類型的大小不同)。 2.同樣x和o​前面也可以使用l來修飾。 3.對於short類型,前面就是使用h來​當首碼。 4.h和l首碼都可以和u ...
  • 關於變數的命名,這又是一個容易引發程式員論戰的話題。如何命名才能更具有可讀性、易寫性與明義性呢?眾說紛紜。 本期“Python為什麼”欄目,我們將聚焦於變數命名中的連接方式,來切入這塊是非之地,想要回答的問題是——Python 為什麼要推薦蛇形命名法? 首先一點,對於單個字元或者單詞 (例如:a、A ...
  • 最近也是在後臺收到很多小伙伴私信問我線程和線程池這一塊的問題,說自己在面試的時候老是被問到這一塊的問題,被問的很頭疼。前幾天看到後幫幾個小伙伴解決了問題,但是問的人有點多我一個個回答也回答不過來,乾脆花了一個上午時間寫了這篇文章分享給大家。話不多說,滿滿的乾貨都在下麵了! ...
  • 一、背景 隨著時間和業務的發展,資料庫中的數據量增長是不可控的,庫和表中的數據會越來越大,隨之帶來的是更高的磁碟、IO、系統開銷,甚至性能上的瓶頸,而一臺服務的資源終究是有限的,因此需要對資料庫和表進行拆分,從而更好的提供數據服務。 當用戶表達到千萬級別,在做很多操作的時候都會很吃力,所以當數據增長 ...
  • 1.數組基礎 數組的定義: 數組是相同類型數據的有序集合。數組描述的是相同類型的若幹數據,按照一定的先後次序排列組合而成的。 其中每一個數據成為元素,每個元素可以通過索引來訪問他們。 數組的三個基本特點: 1.長度確定,數組一旦被創建,它的大小就是不可以改變的。 2.其元素必須是相同類型,不允許出現 ...
  • 前言 本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。 Matplotlib 是一個 Python 的 2D繪圖庫(當然也可以畫三維形式的圖形哦),它以各種硬拷貝格式和跨平臺的互動式環境生成出版質量級別的圖形 。通過 Matplo ...
  • Collection是一種關於集合的類 在Collection類中共有的方法有: add(E e):添加 remove(E e):指定元素刪除 contains(E e):指定元素是否存在 isEmpty():判斷是否為空 size():返回元素個數 to Array():元素變成數組 clean( ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...