照片信息的读取与分类(1)

2024-09-07 15:28
文章标签 读取 分类 信息 照片

本文主要是介绍照片信息的读取与分类(1),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

拿到了照片的拍摄时间后,就可以根据拍摄的年份和月份来确定照片要移动到的文件夹路径了。现在我们来分析一下如何从表示拍摄时间这个字符串中(2015:12:10 21:08:08 )提取出拍摄的年份和月份。
整个字符串由一个空格将拍摄的日期和具体的时间分隔开来

在拍摄日期的部分中,拍摄的年、月、日又被两个冒号分隔开来。
同样的,拍摄时间也被两个冒号分隔成了时、分、秒三个部分。

将示例中拍摄日期分隔成日期和时间,把分隔后的列表赋值给变量takeTimeParts,然后使用两个print分别输出日期和时间。

要对拍摄时间的字符串进行拆解,我们可以使用字符串的内置函数split()
分隔符作为参数传入到split()函数中,即可把字符串按照指定分隔符切分成多个字符串组成的列表。
例如:
字符串 2015:12:10 21:08:08
被“空格”切分后就变成了
["2015:12:10", "21:08:08"]

把拍摄日期通过冒号分隔,分成年、月、日三部分,赋值给变量photoDateParts。再使用print分别输出年、月、日。

将整个拍摄日期通过空格切分后,我们需要把分隔后的“年月日”部分单独赋值给变量photoDate
然后对此字符串再调用一次split()函数,通过冒号将日期分隔成年、月、日。
注意:需要使用英文冒号 进行切分。

利用格式化字符串拼出文件夹名称,并赋值给变量targetFolderName,再使用os.path.join()函数拼出分类文件夹的路径, 并赋值给photoTargetPath变量。最后输出变量photoTargetPath。

学会了通过分隔字符串来提取拍摄的年、月、日之后,下一步就可以通过格式化字符串的方式,以年份和月份为参数给照片文件夹进行命名了(命名格式:xxxx年xx月)。
因为分类的文件夹依然位于 /Volumes/backup/照片路径下,所以我们可以直接使用os.path.join()函数拼出分类文件夹的相对路径。

使用os.path.exists()函数判断照片分类的文件夹是否存在,如果不存在,就使用os.mkdir()函数创建文件夹。

1

# 导入os模块

2

import os

3

4

# 导入ezexif模块

5

import ezexif

6

7

# 修改当前工作目录到/Volumes/backup

8

os.chdir('/Volumes/backup')

9

10

# 待处理照片的相对路径

11

backupPhotoPath = "照片"

12

13

# 使用函数os.listdir()获取所有待处理照片文件列表

14

photoList = os.listdir(backupPhotoPath)

15

16

# 遍历文件列表

17

for photo in photoList:

18

    # 使用os.path.join()函数组合得到照片文件路径,并赋值给变量photoPath

19

    photoPath = os.path.join(backupPhotoPath, photo)

20

    # 获取exif信息

21

    exifInfo = ezexif.process_file(photoPath)

22

    # 获取拍摄时间

23

    takeTime = exifInfo["EXIF DateTimeOriginal"

接下来,我们就需要使用在前面课程中学过的os.path.exists()函数来判断目标文件夹是否存在。
如果目标文件夹不存在,就使用os.mkdir()函数创建文件夹。

导入内置模块shutil,然后将照片文件通过shutil.move()函数移动到目标文件夹。

确保文件夹创建好后,我们只需要使用shutil.move()函数,就可以完成今天问题的最后一步:将照片移动到目标文件夹啦。
注意,使用shutil.move()函数前,记得先使用import导入shutil内置模块哦。

1

# 导入os模块

2

import os

3

4

# 导入ezexif模块

5

import ezexif

6

7

# 导入shutil模块

8

import shutil

9

10

# 修改当前工作目录到/Volumes/backup

11

os.chdir('/Volumes/backup')

12

13

# 将待处理照片的相对路径赋值给backupPhotoPath

14

backupPhotoPath = "照片"

15

16

# 使用函数os.listdir()获取所有待处理照片文件列表

17

photoList = os.listdir(backupPhotoPath)

18

19

# 遍历文件列表

20

for photo in photoList:

21

    # 使用os.path.join()函数组合得到照片文件路径,并赋值给变量photoPath

22

    photoPath = os.path.join(backupPhotoPath, photo)

23

    # 获取exif信息

24

    exifInfo = ezexif.process_file(photoPath)

25

    # 获取拍摄时间

26

    takeTime = exifInfo["EXIF DateTimeOriginal"]

27

    # 通过空格分隔成拍摄日期和拍摄时间

28

    takeTimeParts = takeTime.split(" ")

29

    # 分隔后的字符串列表第一个元素就是拍摄日期,赋值给变量photoDate

30

    photoDate = takeTimeParts[0]

31

    # 再把拍摄日期通过冒号分隔,分成年、月、日三部分,赋值给变量photoDateParts

32

    photoDateParts = photoDate.split(":")

33

34

    # 利用格式化字符串拼出文件夹名称

35

    targetFolderName = f"{photoDateParts[0]}{photoDateParts[1]}"

36

    # 使用os.path.join()函数拼出分类文件夹的路径, 并赋值给photoTargetPath变量

37

    photoTargetPath = os.path.join(backupPhotoPath, targetFolderName)

38

39

    # 如果目标文件夹不存在,使用os.mkdir()函数创建文件夹

40

    if not os.path.exists(photoTargetPath):

41

        os.mkdir(photoTargetPath)

42

43

    # 移动到目标文件夹

44

    shutil.move(photoPath, photoTargetPath)

shutil.move()函数可以用来移动文件或文件夹。它接收两个参数,第一个参数是要移动的文件(夹)路径,第二个参数是目标文件(夹)的路径。

这篇关于照片信息的读取与分类(1)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145431

相关文章

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

C#实现SHP文件读取与地图显示的完整教程

《C#实现SHP文件读取与地图显示的完整教程》在地理信息系统(GIS)开发中,SHP文件是一种常见的矢量数据格式,本文将详细介绍如何使用C#读取SHP文件并实现地图显示功能,包括坐标转换、图形渲染、平... 目录概述功能特点核心代码解析1. 文件读取与初始化2. 坐标转换3. 图形绘制4. 地图交互功能缩放

java读取excel文件为base64实现方式

《java读取excel文件为base64实现方式》文章介绍使用ApachePOI和EasyExcel处理Excel文件并转换为Base64的方法,强调EasyExcel适合大文件且内存占用低,需注意... 目录使用 Apache POI 读取 Excel 并转换为 Base64使用 EasyExcel 处

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日

使用Java读取本地文件并转换为MultipartFile对象的方法

《使用Java读取本地文件并转换为MultipartFile对象的方法》在许多JavaWeb应用中,我们经常会遇到将本地文件上传至服务器或其他系统的需求,在这种场景下,MultipartFile对象非... 目录1. 基本需求2. 自定义 MultipartFile 类3. 实现代码4. 代码解析5. 自定

MySQL 数据库表操作完全指南:创建、读取、更新与删除实战

《MySQL数据库表操作完全指南:创建、读取、更新与删除实战》本文系统讲解MySQL表的增删查改(CURD)操作,涵盖创建、更新、查询、删除及插入查询结果,也是贯穿各类项目开发全流程的基础数据交互原... 目录mysql系列前言一、Create(创建)并插入数据1.1 单行数据 + 全列插入1.2 多行数据

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

SQL Server跟踪自动统计信息更新实战指南

《SQLServer跟踪自动统计信息更新实战指南》本文详解SQLServer自动统计信息更新的跟踪方法,推荐使用扩展事件实时捕获更新操作及详细信息,同时结合系统视图快速检查统计信息状态,重点强调修... 目录SQL Server 如何跟踪自动统计信息更新:深入解析与实战指南 核心跟踪方法1️⃣ 利用系统目录

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo