讲解Windows系统中如何使用Python读取图片的元数据【Metadata】

news2024/11/20 19:23:07

文章目录

  • 简介
    • 图像元数据
    • 如何查看图像元数据
    • pyexiv2
    • pyexiv2读取图片的元数据的函数接口
    • 主要部分pyexiv2的EXIF元数据说明
  • 代码示例
  • 参考资料

简介

我们可以使用pyexiv2这个Python第三方工具在Windows系统中包读取图片文件的元数据Metadata。其中,经常会使用的图片元数据一般是有关图片格式的EXIF😄和版权的IPTC数据😄。此篇博客介绍了pyexiv2的安装和基本使用方法,并提供了Python代码示例。当然,pillow也可以查看图片的元数据,文中也直接给出了pillow查看图片元数据的代码示例。😆😆

PS:若图片数据已经被抹去了元数据信息,pyexiv2可能读不到任何数据!比如下面这一行COCO数据中的图片,就无法读取相关信息。建议拿一张自己拍摄的照片尝试一下。

图像元数据

图像元数据是指存储在数字图像文件中的附加信息,用于描述有关图像的各种属性和特征。这些元数据提供了关于图像的详细信息,方便组织、搜索和理解图像内容。通过使用工具如Pyexiv2,用户可以轻松访问和编辑这些元数据,以满足各种需求。常见的图像元数据包括:

  • EXIF(Exchangeable Image File Format)数据⭐️⭐️🚀🚀:这是最常见的图像元数据之一,包括了拍摄日期和时间、相机型号、曝光时间、光圈值、ISO感光度、焦距、闪光灯状态等与拍摄条件有关的信息。

  • IPTC(International Press Telecommunications Council)数据⭐️🚀:通常包含有关图像的描述性信息,如标题、作者、版权、关键字和特殊说明。

  • XMP(Extensible Metadata Platform)数据:提供了一种灵活的方法来存储和管理图像的元数据,包括自定义标签、扩展属性和附加信息。

  • GPS信息:如果启用了GPS功能,图像元数据可以包括拍摄地点的经纬度坐标,使用户能够准确地知道图像拍摄的地理位置。

  • 色彩空间信息:描述图像的色彩空间,如sRGB、Adobe RGB等。

  • 文件格式和压缩参数:指定图像的文件格式(如JPEG、PNG)和压缩设置。

  • 图像分辨率:图像的宽度和高度以及像素密度信息。

  • 修改历史:包含了有关图像编辑和修改的信息,如编辑软件、编辑日期和历史记录。

如何查看图像元数据

方法1:Windows查看图片属性,选择详细信息
在这里插入图片描述
方法2:图片导入Photoshop,快捷键Ctrl+Alt+Shift+I
在这里插入图片描述

pyexiv2

Pyexiv2是一个用于处理图像元数据的Python第三方库。它允许您轻松读取和编辑照片和图像文件的元数据信息,如EXIF(Exchangeable Image File Format)数据、IPTC(International Press Telecommunications Council)标签和XMP(Extensible Metadata Platform)属性。这些元数据包含了有关图像的重要信息,如拍摄日期、相机型号、GPS坐标和作者信息等。

Pyexiv2提供了一个简单而强大的接口,允许你从图像文件中提取有关图像的信息,如拍摄日期、相机型号、光圈、快门速度等。你还可以使用它来添加、修改或删除图像的元数据,以满足特定需求。这在图像处理和管理中非常重要,因为它可以帮助你自动化和个性化图像的处理过程。

总之,Pyexiv2是一个用于Python的元数据处理库,提供了方便的工具,用于访问和编辑图像文件中的元数据信息,使图像处理和管理更加灵活和高效。无论你是处理照片、构建图像相关应用还是进行数字档案管理,Pyexiv2都是一个有用的工具。

pyexiv2读取图片的元数据的函数接口

  • read_exif
  • read_comment
  • read_icc
  • read_iptc
  • read_raw_xmp
  • read_thumbnail
  • read_xmp
with pyexiv2.Image(filename="000000000009.jpg") as img:
    exif = img.read_exif()
    comment = img.read_comment()
    icc = img.read_icc()
    iptc = img.read_iptc()
    raw_xmp = img.read_raw_xmp()
    thumbnail = img.read_thumbnail()
    xmp = img.read_xmp()

主要部分pyexiv2的EXIF元数据说明

这些都是调用read_exif可能返回的元数据字典的key。

元数据说明
Exif.Image.ImageWidth图片宽度
Exif.Image.Model拍摄设备与型号
Exif.Image.Orientation图片方向
Exif.Image.DateTime拍摄日期
Exif.Image.YCbCrPositioning色相定位
Exif.Photo.ExposureTime曝光时间
Exif.Photo.FocalLength焦距
Exif.Photo.LightSource光源
Exif.Photo.BrightnessValue亮度
Exif.Photo.ColorSpace色彩空间
Exif.Image.XResolutionX方向分辨率
Exif.Image.YResolutionY方向分辨率

相关参数还有很多,自出表格不再一一列举。感兴趣可自行查看!

代码示例

读取图片EXIT元数据,修改图片EXIT元数据,调用pillow查看图片元数据。
yifeiliu.jpg
在这里插入图片描述

import pyexiv2
from PIL import Image

def read_exif_metadata(img_path):
    """调用pyexiv2读取图片的EXIF元数据, 并返回一个数据字典"""
    with pyexiv2.Image(filename=img_path, encoding="utf-8") as pyexiv2_img:
        exif_metadata = pyexiv2_img.read_exif()

    return exif_metadata


def set_exif_metadata(img_path, metadata_dict: dict):
    """调用pyexiv2修改图片的EXIF元数据, 成功返回True, 失败返回False"""
    try:
        with pyexiv2.Image(filename=img_path, encoding="utf-8") as pyexiv2_img:
            pyexiv2_img.modify_exif(metadata_dict)

        return True
    except Exception as e:
        print(e)
        return False
    
def read_exif_metadata_PIL(img_path):
    """调用pillow读取图片的EXIF元数据, 并返回一个数据字典"""
    with Image.open(fp=img_path) as pillow_img:
        exif_metadata = pillow_img.getexif()

    return exif_metadata


def clear_exif_metadata(img_path):
    """调用pyexiv2清除图片的EXIF元数据, 成功返回True, 失败返回False"""
    try:
        with pyexiv2.Image(filename=img_path, encoding="utf-8") as pyexiv2_img:
            pyexiv2_img.clear_exif()

        return True
    except Exception as e:
        print(e)
        return False
    

if __name__ == "__main__":
    metadata = read_exif_metadata("yifeiliu.jpg")
    print(f"第1次读取EXIF元数据: {metadata}")
    metadata_dict = {
        "Exif.Image.Model": "Cannon R3",
        "Exif.Image.ImageWidth": 1202,
        "Exif.Image.ImageLength": 676
    }
    ret = set_exif_metadata("yifeiliu.jpg", metadata_dict)
    metadata = read_exif_metadata("yifeiliu.jpg")
    print(f"第2次读取EXIF元数据: {metadata}")
    metadata = read_exif_metadata_PIL("yifeiliu.jpg")
    print(f"第3次读取EXIF元数据(pillow) {metadata}")
    ret = clear_exif_metadata("yifeiliu.jpg")
    metadata = read_exif_metadata("yifeiliu.jpg")
    print(f"第3次读取EXIF元数据(清除数据后): {metadata}")

结果:
在这里插入图片描述

参考资料

  1. Github:pyexiv2
  2. pyexiv2中文教程
  3. Welcome to py3exiv2’s documentation!⭐️
  4. CSDN:Python用pyexiv2读写图片元数据(EXIF、IPTC、XMP)
  5. https://www.osgeo.cn/python-tutorial/imgs-exif.html

收集整理和创作不易, 若有帮助🉑, 请帮忙点赞👍➕收藏❤️, 谢谢!✨✨🚀🚀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1098688.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

你了解供应链云仓系统源码里的5个核心功能吗?

为您详细介绍供应链云仓系统源码中的核心功能 供应链云仓系统是一种基于互联网的供应链管理系统,它利用云计算和大数据技术,帮助企业优化物流与库存管理、提升供应链的效率和灵活性。在供应链云仓系统的源码中,有许多关键功能可以帮助企业实现…

【Java 进阶篇】JavaScript 自动跳转首页案例

在这篇博客中,我们将创建一个JavaScript案例,演示如何自动跳转到网站的首页。这种自动跳转通常用于欢迎页面或广告页面等场景。我们将从头开始创建这个案例,逐步介绍相关的JavaScript知识,让初学者也能理解并实现这个功能。 1. 什…

【docker】查看容器日志

目录 一.通过查找宿主机日志路径,通过Linux命令查看即可。 1.1 查看容器日志路径 1.2 按照日志路径检索日志 二、通过docker命令检索日志 2.1 查看指定时间后的日志,只显示最后20行 2.2 查看最近10分钟的日志 2.3 查看某时间段之后的日志 2.4 查…

Java武侠文字游戏

import java.util.Random;public class Role {//姓名private String name;//血量private int blood;//性别private char gender;//长相(随机)private String face;String[] boyfaces {"风流俊雅", "气宇轩昂", "相貌英俊", "五官端正"…

【00】神经网络之初始化参数

问题描述 #随机初始化权重 w12 np.random.randn(100, 784)/np.sqrt(784) 为什么除以28 回答 这里的代码是初始化一个深度学习模型中的权重矩阵w12。权重矩阵的形状是(100, 784),这是一个从784个输入节点到100个隐藏节点的全连接层。 除以np.sqrt(784)是权重初始…

web 性能优化详解(Lighthouse工具、优化方式、强缓存和协商缓存、代码优化、算法优化)

1.性能优化包含的方面 优化性能概念宽泛,可以从信号、系统、计算机原理、操作系统、网络通信、DNS解析、负载均衡、页面渲染。只要结合一个实际例子讲述清楚即可。 2.什么是性能? Web 性能是客观的衡量标准,是用户对加载时间和运行时的直观…

微信小程序框架---详细教程

🎬 艳艳耶✌️:个人主页 🔥 个人专栏 :《Spring与Mybatis集成整合》《Vue.js使用》 ⛺️ 越努力 ,越幸运。 目录 1.框架 1.1响应的数据绑定 1.2.页面管理 1.3.基础组件 1.4.丰富的 API 2.视图层 View 2.1.介绍 …

大量pod失败

随便查看pod 有的pod提示磁盘不足 查看csi-nfs 的pod。有一个处于Evicted 状态 kubectl get pod -n kube-system csi-nfs-node-jlxc6 3/3 Running 10 (4d16h ago) 20d csi-nfs-node-vnr5q 0/3 Evicted 0 10m 查看这个pod。提示磁盘不足 kubectl describe pod -n kube-system…

低代码技术这么香,如何把它的开发特点发挥到极致?

前言 什么是低代码技术? 低代码是一种可视化软件开发方法,通过最少的编码更快地交付应用程序。图形用户界面和拖放功能使开发过程的各个方面自动化,消除了对传统计算机编程方法的依赖。 文章目录 前言低代码平台怎么选?用友Yonbu…

14.8 Socket 一收一发通信

通常情况下我们在编写套接字通信程序时都会实现一收一发的通信模式,当客户端发送数据到服务端后,我们希望服务端处理请求后同样返回给我们一个状态值,并以此判断我们的请求是否被执行成功了,另外增加收发同步有助于避免数据包粘包…

docker基础认知(镜像+容器+仓库+客户端与服务器)

镜像(Image) 静态文件,提供了容器运行时所需的程序、库、资源、配置等文件,另外包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。(相比文件的说法,文件系统的说…

Mac电脑空间不足怎么办?如何优化系统

随着使用时间的增长,我们会发现Mac电脑的存储空间越来越少,这时候我们就需要对Mac电脑进行清理,以释放更多的存储空间。那么,Mac空间不足怎么解决呢? 1.清理垃圾文件 Mac空间不足怎么解决?首先要做的就是…

Go语言入门心法(七): 并发与通道

Go语言入门心法(一): 基础语法 Go语言入门心法(二): 结构体 Go语言入门心法(三): 接口 Go语言入门心法(四): 异常体系 Go语言入门心法(五): 函数 一: go语言并发与通道

身份证照片怎么弄成200k以内?三个方法轻松搞定!

在日常生活中,为了方便上传和保存、便于传输和处理以及符合相关规定等方面的考虑,身份证照片大小常常被要求控制在200k以内,可是手机随便一拍,任凭如何截图都在超过1M,这个时候就需要借助一些图片压缩工具,…

汽车电子 -- CAN报文接收解析和发送组包

之前已经讲过如何生成DBC文件了,程序中该如何解析DBC呢? 其中包括接收CAN报文解析和发送CAN报文组包?? 一、Motorola和Intel格式 dbc里的信号Signals,其中里面有两种数据格式 Motorola和Intel格式。 之前C语言里&…

win11点击任务栏固定的应用:该文件没有与之关联的应用来执行该操作

点击固定在任务栏的任何图标提示 1、直接点击“开始”旁边的搜索按钮,搜索“注册表编辑器”。 2、找到HKEY_CLASSES_ROOT\lnkfile(注意“lnkfile”的l是小写L不是大写i),在右侧新建一个字符串值“IsShortcut”的文件&#xff1…

大模型的背景与现状问题

一、大模型的发展背景 谈起大模型,第一时间想到的是什么?是主流的ChatGPT?或者GPT4?还是DALL-E3?亦或者Midjourney?以及Stablediffusion?还是层出不穷的其他各类AI Agent应用工具?大…

攻防千层饼

近年来,网络安全领域正在经历一场不断升级的攻防对抗,这场攻防已经不再局限于传统的攻击与防御模式,攻击者和防守者都已经越发熟练,对于传统攻防手法了如指掌。 在这个背景下,攻击者必须不断寻求创新的途径&#xff0…

【C++】头文件chrono

2023年10月16日,周一晚上 当前我只是简单的了解了一下chrono 以后可能会深入了解chrono并更新文章 目录 功能原理头文件chrono中的一些类头文件chrono中的数据类型一个简单的示例程序小实验:证明a的效率比a高 功能 这个chrono头文件是用来处理时间的…

git log 美化配置

编辑 vim ~/.gitconfig 添加配置 [alias]lg log --graph --abbrev-commit --decorate --dateformat:%m-%d %H:%M:%S --formatformat:%C(bold blue)%h%C(reset) - %s %C(bold yellow)% d%C(reset) %n %C(dim white) (%ad) - %an%C(reset) --allgit lg 效果