【办公类-04-02】华为助手导出照片读取拍摄时间分类导出,视频不行)

背景需求

今天我用QQ相册导出照片,但是始终在转圈,手机上无法跳出“连结“”的提示,换了台式和笔记本都无法传输。(明明5月14日还可以导出的)

最后我只能用华为传输助手,把照片快速提取出来了。

使用原来的日期分类代码

【办公类-04】VS python手机照片视频按日期文件夹整理_视频按日期分类-CSDN博客文章浏览阅读1.7k次,点赞2次,收藏2次。【办公类-04】VS python手机照片视频按日期文件夹整理_视频按日期分类https://blog.csdn.net/reasonsummer/article/details/122583051

import datetime
import os
import shutil
import timeallFileNum = 0# 所有文件数量从0开始
myfile=[]# 我的文件
mydir=[]# 我的列表
movie_file_format=['avi','mpeg','mp4','mov','ProRes','DNxHR','mfx','mkv','wmv','flv','rmvb','webm','asf']# 视频格式
text_file_format=['DOC','PDF','HTML','TXT','HTL','DOCX']# 文本格式
img_file_format=['bmp','jpg','jpeg','png','tif','gif','pcx','tga','exif','fpx','svg','psd','cdr','pcd','dxf','ufo','eps','ai','raw','WMF','webp','avif','hdri','flic','emf','ico']# 图片格式
zip_file_format=['rar' ,'zip','7z','CAB','ARJ','LZH','TAR','GZ','ACE','UUE','BZ2','JAR','ISO','MPQ']# 压缩格式
music_file_format=['PCM','WAV','AIFF','MP3','AAC','OGG','WMA','FLAC','ALAC','WMA']# 音乐格式this_folder= 'D:\\03照片导出' # 整理前的照片所在文件夹,原始路径:
# this_folder=input("原始路径:").replace("\\",'/')
those_folder='D:\\04照片整理'# 整理后的照片所在文件夹(原照片删除),目标路径:
# those_folder=input("目标路径:").replace("\\",'/')def printPath(level, path):# 定义输出路径(层级,路径字符串)global allFileNum    # 返回allFileNum的全局变量'''''打印一个目录下的所有文件夹和文件'''# 所有文件夹,第一个字段是次目录的级别dirList = []    # 目录清单# 所有文件fileList = []# 返回一个列表,其中包含在目录条目的名称(google翻译)files = os.listdir(path)# 先添加目录级别dirList.append(str(level))for f in files:if (os.path.isdir(path + '/' + f)):  # os.path.isdir()用于判断对象是否为一个目录if (f[0] == '.'):# 排除隐藏文件夹。因为隐藏文件夹过多passelse:# 添加非隐藏文件夹dirList.append(f)# mydir.append(path + '/' + f)if (os.path.isfile(path + '/' + f)):# 添加文件fileList.append(f)myfile.append(path + '/' + f)# 当一个标志使用,文件夹列表第一个级别不打印i_dl = 0for dl in dirList:if (i_dl == 0):i_dl = i_dl + 1else:# print("得到的文件夹",'-' * (int(dirList[-1])), dl)# 打印目录下的所有文件夹和文件,目录级别+1printPath((int(dirList[0])+1), path + '/' + dl)for fl in fileList:# print("得到的文件路径",'-' * (int(dirList[-1])), fl)# 随便计算一下有多少个文件allFileNum = allFileNum + 1def judge_file(oldPath,location):    # 定义判断文件(老文件,位置)def TimeStampToTime(timestamp):# 定义时间转戳时间(时间戳)timeStruct = time.localtime(timestamp)#时间结构体等于,格式化时间戳为本地的时间(时间戳)return time.strftime('%Y-%m-%d %H:%M:%S', timeStruct)#返回本地时间戳(结构累心,时间结构体)def get_file_format(file_path):        # 定义获取后的文件格式(文件路径)file_name=file_path.split("/")[-1]        #文件名称等于 文件路径 的最后一段 split("/")[-1]  以‘/ ’为分割f符,保留最后一段# if file_name.find(".")>0:#     file_format=file_name.split('.')[-1] #文件名称等于 文件路径 的最后一段#     if file_format.lower() in movie_file_format or file_format.upper() in movie_file_format:#         return "视频"#     # elif file_format.lower() in text_file_format or file_format.upper() in text_file_format:#     #     return "文本"#     elif file_format.lower() in img_file_format or file_format.upper() in img_file_format:#         return "图片"#     elif file_format.lower() in music_file_format or file_format.upper() in music_file_format:#         return "音频"#     elif file_format.lower() in zip_file_format or file_format.upper() in zip_file_format:#         return "压缩"#     else:#         return "其他"  # else:#     return "文本"def move_file(new_dir):#定义转移文件 新的列表old_file_name = oldPath.split("/")[-1]#老文件名等于老路径的最后一段# 将文件移动到新文件夹shutil.move(oldPath, new_dir + '/' + old_file_name)  # a->bprint("-"*50+"已完成:%.2f" % ((location + 1) / allFileNum*100))# ImageDate = datetime.datetime.strftime(time.ctime(os.stat(imgPath).st_mtime), "%Y-%m-%d %H:%M:%S")a = os.stat(oldPath).st_mtime    # 文件时间戳 os.stat(老路径文件).st_mtime#得到文件创建时间,判断文件夹是否存在creat_time=TimeStampToTime(a)[:-9]# 创造时间戳print(creat_time) #打印创造的时间 str 2021-01-10 10:05:31folder_format=get_file_format(oldPath)# 新列表展示为三段式结构——整理后的路径(一级文件夹),创造的时间(二级文件夹),文件格式(图片 视频等 三级文件夹)# new_dir="%s/%s/%s"%(those_folder,creat_time,folder_format)    # 阿夏需要两级文件夹(整理后的路径(一级文件夹),创造的时间(二级文件夹)里面装了混合的照片和视频。手动整理)new_dir="%s/%s"%(those_folder,creat_time)#不存在文件夹则创建文件夹if not os.path.exists(new_dir):os.makedirs(new_dir)move_file(new_dir)#如果存在就判断是否是重复文件else :if oldPath.split("/")[-1] in os.listdir(new_dir):print("重复文件,略过")passelse:move_file(new_dir)
def do_all():for i in myfile:judge_file(i,myfile.index(i))
printPath(1, this_folder)
do_all()
input()
# ————————————————
# 版权声明:本文为CSDN博主「lidashent」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
# 原文链接:https://blog.csdn.net/lidashent/article/details/113919375

结果只出现一个文件夹。(从4月26-6月4日)

发现程序可能按照“修改日期”整理文件了,而不是按照拍摄日期整理

华为助手导出照片,按照创建日期生成了,我需要按照拍摄日期文件夹整理)让AI修改代码内容。

代码展示:

'''
QQ相册导出失灵后,使用华为助手导出照片,结果4月28日-6月4日的照片都打包在6月4日文件夹里
运用AI对话大师将原来的代码进行修改。实现按如期分类华为手机助手导出的照片,指定读取拍摄时间(只能转移照片,视频不行)
作者:AI对话大师
时间:2024年6月4日'''import os
import shutil
import exifreadallFileNum = 0
myfile = []
mydir = []
img_file_format = ['bmp', 'jpg', 'jpeg', 'png', 'tif', 'gif', 'pcx', 'tga', 'exif', 'fpx', 'svg', 'psd','cdr', 'pcd', 'dxf', 'ufo', 'eps', 'ai', 'raw', 'WMF', 'webp', 'avif', 'hdri', 'flic', 'emf', 'ico']
video_file_format = ['avi', 'mpeg', 'mp4', 'mov', 'ProRes', 'DNxHR', 'mfx', 'mkv', 'wmv', 'flv', 'rmvb', 'webm', 'asf']
text_file_format = ['DOC', 'PDF', 'HTML', 'TXT', 'HTL', 'DOCX']
# 添加其他文件类型列表this_folder = 'D:\\03照片导出'
those_folder = 'D:\\04照片整理'def printPath(level, path):global allFileNumdirList = []fileList = []files = os.listdir(path)dirList.append(str(level))for f in files:if (os.path.isdir(path + '/' + f)):if (f[0] == '.'):passelse:dirList.append(f)if (os.path.isfile(path + '/' + f)):fileList.append(f)myfile.append(path + '/' + f)i_dl = 0for dl in dirList:if (i_dl == 0):i_dl = i_dl + 1else:printPath((int(dirList[0]) + 1), path + '/' + dl)for fl in fileList:allFileNum = allFileNum + 1def get_file_format(file_path):file_name = file_path.split("/")[-1]file_format = file_name.split('.')[-1]if file_format.lower() in img_file_format:return ""elif file_format.lower() in video_file_format:return ""elif file_format.lower() in text_file_format:return ""# 添加其他文件类型判断条件else:return ""def move_file(oldPath, new_dir):old_file_name = oldPath.split("/")[-1]shutil.move(oldPath, new_dir + '/' + old_file_name)print("-" * 50 + "已完成:%.2f" % ((myfile.index(oldPath) + 1) / allFileNum * 100))def get_create_time(file_path):with open(file_path, 'rb') as f:tags = exifread.process_file(f)if 'EXIF DateTimeOriginal' in tags:datetime_original = tags['EXIF DateTimeOriginal']return str(datetime_original).split()[0].replace(":", "-")return ""def judge_file(oldPath, location):create_time = get_create_time(oldPath)if create_time:folder_format = get_file_format(oldPath)new_dir = "%s/%s/%s" % (those_folder, create_time, folder_format)if not os.path.exists(new_dir):os.makedirs(new_dir)move_file(oldPath, new_dir)else:print("无法获取拍摄日期,跳过文件:" + oldPath)def do_all():for i in myfile:judge_file(i, myfile.index(i))printPath(1, this_folder)
do_all()
input()import os
import subprocessvideo_file_format = ['avi', 'mpeg', 'mp4', 'mov', 'ProRes', 'DNxHR', 'mfx', 'mkv', 'wmv', 'flv', 'rmvb', 'webm', 'asf']def get_video_create_time(file_path):if file_path.split('.')[-1].lower() not in video_file_format:return ""command = ['ffprobe', '-v', 'quiet', '-print_format', 'json', '-show_format', file_path]result = subprocess.run(command, capture_output=True, text=True)if result.returncode == 0:try:metadata = result.stdoutcreation_time = metadata['format']['tags']['creation_time']return creation_time.split('T')[0]except (KeyError, IndexError):passreturn ""def judge_file(oldPath, location):create_time = get_create_time(oldPath)if not create_time:create_time = get_video_create_time(oldPath)if create_time:folder_format = get_file_format(oldPath)new_dir = "%s/%s/%s" % (those_folder, create_time, folder_format)if not os.path.exists(new_dir):os.makedirs(new_dir)move_file(oldPath, new_dir)else:print("无法获取拍摄时间,跳过文件:" + oldPath)# 在 judge_file 函数中添加了对视频文件的处理。首先,我们尝试使用 get_create_time 函数获取拍摄时间。如果获取不到,则调用 get_video_create_time 函数来获取视频文件的拍摄时间。如果最终无法获取到拍摄时间,则跳过处理该文件。

看看是否可以想办法读取照片、视频的文件名,将图片、视频进行剪切转移黏贴。

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

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

相关文章

从记忆到想象:探索AI的智能未来

引言 人工智能(AI)在信息处理、数据分析和任务自动化等方面展现了强大的能力。然而,在人类独有的记忆和想象力领域,AI仍然有很长的路要走。加利福尼亚大学戴维斯分校的心理学和神经科学教授查兰兰加纳特(Charan Ranga…

STM32编程:实现LED灯闪烁(基于手写SDK的方式)

项目结构 stm32f10x.h 文件 //寄存器的值常常是芯片外设自动更改的,即使CPU没有执行程序,也有可能发生变化 //编译器有可能会对没有执行程序的变量进行优化//volatile表示易变的变量,防止编译器优化, #define __IO volati…

Linux(Rocky)下 如何输入中文(切换中文输入法)教程

RockyLinux如何输入中文(切换中文输入法) 注意 在字符画界面的Linux系统中 默认不具备中文输入法的功能 需要SSH或其他远程工具来实现 问题 可能大家有的时候安装了一个虚拟机之后 想切换中文输入法 但是一直找不到方法 下面将利用Rocky9.2作为演示…

Failed to build causal-conv1d -- 离线安装(mamba_ssm)

Building wheels for collected packages: causal-conv1d Building wheel for causal-conv1d (setup.py) … error error: subprocess-exited-with-error python setup.py bdist_wheel did not run successfully. │ exit code: 1 ╰─> [8 lines of output] torch.__versi…

苹果将推出“Apple Intelligence”AI系统,专注于隐私和广泛应用|TodayAI

据彭博社报道,苹果公司将在下周的 WWDC 2024 开发者大会上揭晓其全新的 AI 系统——“Apple Intelligence”,该系统将适用于 iPhone、iPad 和 Mac 设备。这一新系统将结合苹果自身技术和 OpenAI 的工具,为用户提供一系列新的 AI 功能&#xf…

独立游戏之路 -- TapTap广告收益损失和常见问题

一个操作带来的TapTap广告收益损失 一,收益损失1.1 广告入口1.2 损失对比二,常见问题2.1 有展现量没有预估收益 /eCPM 波动大?2.2 新建正式媒体找不到预约游戏2.3 聚合模式由于没有回传 oaid 无数据2.4 每日观看次数限制是否有限制一,收益损失 1.1 广告入口 TapTap广告联…

【JAVASE】日期与时间类(下)

三:LocalDateTime 相当于LocalDate类,在LocalDateTime类的对象中还可以封装时、分、秒和纳秒(1纳秒是1秒的十亿分之一)等时间类型。 例如,创建LocalDateTime对象 , LocalDateTime date LocalDateTi…

动手学深度学习29 残差网络ResNet

动手学深度学习29 残差网络ResNet ResNet代码ReLU的两种调用1. 使用 torch.nn.ReLU 模块2. 使用 torch.nn.functional.relu 函数总结 QA29.2 ResNet 为什么能训练处1000层的模型ResNet的梯度计算怎么处理梯度消失的 QA ResNet 更复杂模型包含小模型,不一定改进&…

Shell以及Shell编程

Shell的任务 ①分析命令; ②处理通配符、变量替换、命令替换、重定向、管道和作业控制; ③搜索命令并执行。 内部命令:内嵌在Shell中。 外部命令:存在于磁盘上的独立可执行文件。 #!/bin/bash #! 称为一个幻数&…

Polar Web【中等】你知道sys还能这样玩吗

Polar Web【中等】你知道sys还能这样玩吗 Contents Polar Web【中等】你知道sys还能这样玩吗思路&探索源码 EXPPHP测试生成十六进制化的命令上传测试 Python 脚本 运行&总结 思路&探索 本题属实是有些…即使提示了sys也难以迅速想到 /sys.php 这个路径,…

MySQL—多表查询—多表关系介绍

一、引言 提到查询,我们想到之前学习的单表查询(DQL语句)。而这一章节部分的博客我们将要去学习和了解多表查询。 对于多表查询,主要从以下7个方面进行学习。 (1)第一部分:介绍 1、多表关系 2、…

每日5题Day18 - LeetCode 86 - 90

每一步向前都是向自己的梦想更近一步,坚持不懈,勇往直前! 第一题:86. 分隔链表 - 力扣(LeetCode) /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;…

Vue前端在线预览文件插件

Vue前端在线预览文件插件 一、使用场景 1.1.像文档资料等,只想让他人在线预览,但不能下载。此等场景需求可以用到此插件。 二、此文档介绍两种插件 1.view.xdocin插件 (上线后免费几天,然后收费,添加作者后,可以延…

二叉树的实现(初阶数据结构)

1.二叉树的概念及结构 1.1 概念 一棵二叉树是结点的一个有限集合,该集合: 1.或者为空 2.由一个根结点加上两棵别称为左子树和右子树的二叉树组成 从上图可以看出: 1.二叉树不存在度大于2的结点 2.二叉树的子树有左右之分,次序不能…

DevOps入门

DevOps: 让技术团队、运维、测试等团队实现一体式流程自动化 CICD: CI:持续集成 CD:持续交付持续集成:从编码、编译、测试、发布项目到仓库的自动化流程持续交付:包含持续集成,并且增加将项目部署到对应的环境的自动化流程 传统项目闭环流程: DevOps闭环流程…

软考架构-计算机网络考点

会超纲,3-5分 网络分类 按分布范围划分 局域网 LAN 10m-1000m左右 房间、楼宇、校园 传输速率高 城域网 MAN 10km 城市 广域网 WAN 100km以上 国家或全球(英特网) 按拓扑结构划分 总线型:利用率低、干…

问题:设备管理指标为完好率不低于( ),待修率不高于5%,事故率不高于1%。 #知识分享#经验分享#经验分享

问题:设备管理指标为完好率不低于( ),待修率不高于5%,事故率不高于1%。 A、100% B、95% C、90% D、80% 参考答案如图所示

思维,CF1575K - Knitting Batik

目录 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 二、解题报告 1、思路分析 2、复杂度 3、代码详解 一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 1575K - Knitting Batik 二、解题报告 1、思路分析 诈骗题,上面…

Android开机动画关闭流程

一步一图项目上要加一个开机动画结束的回调,我这边看下如何加 好,老规矩,如何启动动画?动画是谁启动的?怎么关闭的?谁通知关闭的 带着问题看源码 动画的启动流程 开机动画的主入口在哪? 这个…

数据结构--线性表和串

个人介绍 hello hello~ ,这里是 code袁~💖💖 ,欢迎大家点赞🥳🥳关注💥💥收藏🌹🌹🌹 🦁作者简介:一名喜欢分享和记录学习的…