windows系统下利用python对指定文件夹下面的所有文件的创建时间进行修改
windows系统下利用python对指定文件夹下面的所有文件的创建时间进行修改
不知道其他的朋友们有没有这个需求哈,反正咱家是有这个需求
需求1、当前有大量的文件需要更改文件生成的时间,因为不可告知的原因,当前的文件创建时间是不能满足使用的
需求2、更改后的时间不能是一样的,不能被看出来是文件是一起保存的,也就是说看着像是每个文件单独报错的(创建时间不一致)
看需求只有一个是不是非常的简单,但是吧。利用python来实现起来也是非常简单的,如果不信的话,大家可以跟着小编的文章往下面看哈,简单易学,一学就会,相信小编也是相信自己哈
基础环境
| 主机版本 | python版本 |
|---|---|
| win10系统 | python3.8.6 |
先来看看效果
一看效果大家就知道,小编的这个文章是实现的一个什么的功能了
小编这里只是修改了 分钟和秒的时间变得随机了,看着就不像是作假的拉,当然了,代码里面可以进行更改的,大家想更改那个时间可以更改那个时间,比如改年,月,日,时,都可以。小编这里只是提供了一个大概的思路而已,文章最后有完整的代码。
当前有这么的一个文件夹,下面有好多的好多的文件,当然了,小编这边是整理了几个测试专用的文件,文件不是很多,但是也是把各种格式的文件都是整理了一下

开始运行下代码:

查看文件创建时间修改结果:

人狠话不多,直接开始搞
先import我们需要的几个包
#!/usr/bin/env python
# -*- coding: utf-8 -*-import random ###产生随机数的,方便咱们文件的创建时间达到不一致的效果
import tkinter as tk ###作用与UI界面的
import os #####作用与当前的额winows系统的,比如文件的打开关闭,当前的路径等需要这个模块
###下面的两个就是用来修改时间用的,比较关键的
from win32file import CreateFile, SetFileTime, GetFileTime, CloseHandle
from win32file import GENERIC_READ, GENERIC_WRITE, OPEN_EXISTING
###下面的都是时间的模块,当然了可能有人说为什么使用这么多的模块,小编只是懒,怎么方便怎么用,大家可以研究下减少模块来实现
from pywintypes import Time
import time
import datetime
创建UI操作窗口,看起来更逼真
小编的这个窗口还是比较简单的,大家可以根据自己的需要定制一个自己的窗口
root = tk.Tk() # 创建窗口对象
root.title("指定目录下文件时间批量修改 -----文件辅助程序 v2.10 ")
root.geometry("550x300")
·
·
·
·
中间内容下面补充
·
·
·
·# 显示当前进行的操作,以及提示
####会在窗口出现一个白板,来显示我们运行的结果
jg = tk.LabelFrame(root,text="当前进展展示",padx=5,pady=5)
jg.grid(row=0,columnspan=2,sticky='w',padx=10,pady=10)text=tk.Text(jg,width=70,height=15)
scroll=tk.Scrollbar(jg)
scroll.grid(row=0,column=1)
text.grid(row=0,column=0)
scroll.config(command=text.yview)
text.config(yscrollcommand=scroll.set)tk.Button(root, text="文件时间修改", width=25, command=Start).grid(row=1,columnspan=2,padx=10, pady=10) # s南边也就是下边
###点击文件时间修改按钮,会出发Start这个函数,接下来我们就补充这个函数root.mainloop() # 进入消息循环
效果:

Start函数的编写
def Start():#获取当天日期TIME = datetime.datetime.now()"""定义当前的时间并获取当前的时间:year #当前年份,如果有自己的需求,这里可以进行更改,eg year=2023:month ###当前月,如果有自己的需求,这里可以进行更改:day ###当前天,如果有自己的需求,这里可以进行更改:hour ####当前时,r如果有自己的需求,这里可以进行更改"""year = int(TIME.strftime("%Y"))month = int(TIME.strftime("%m")) day = int(TIME.strftime("%d")) hour = int(TIME.strftime("%H")) ####白板展示,可以写成一个函数,但是小编没写,总共用不了几下text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, "当前时间已经生成。。。。。。。。")####需要更改文件所在的目录path = "D:\\wenjian" ###根据自己的实际位置进行更改####白板展示text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, "正在处理文件,请稍等。。。。。。。。")# findfile(path)###批量更改文件时间"""将year,month,day,hour,path传递给fileChangTime函数,执行具体的文件创建日期的修改"""fileChansTime(year,month,day,hour,path)
fileChansTime函数的编写
def fileChansTime(year,month,day,hour,path):####循环path这个文件夹下面的所有文件file_list = os.listdir(path)for file_name in file_list:###调用分钟和秒函数,来随机生成分钟和秒,并赋值minute = Minute()second = Second()##修改文件创建时间o = str(year) +"-" + str(month) + "-" + str(day) +" " + str(hour) + ":" + str(minute) + ":" + str(second)###小编这里将创建时间、修改时间和访问时间都设置成一样的拉,可以根据自己的需要设置成不一样cTime = o # 创建时间mTime = o # 修改时间aTime = o # 访问时间offset = (0, 10, 30) # 偏移的秒数# 拼接文件路径,文件存在才能成功(可以写绝对路径,也可以写相对路径,小编这里是绝对路径)A = path + "\\" + file_name# 调用modifyFileTime函数(文章下面有)修改文件创建时间,并判断是否修改成功r = modifyFileTime(A, cTime, mTime, aTime, offset)if r == 0:print('修改完成')text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, file_name+"编辑时间的随机分钟和秒数已经更改成功")elif r == 1:text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, file_name+"编辑时间的随机分钟和秒数更改失败,请手动更改")
分钟和秒的函数的编写
这里可以写成一个函数来达到效果,小编这里是写了两个,但是不影响效果
如果大家需要更改年,月,日,时的随机值的话,可以参照这个办法进行定义一下,并在Start函数中进行调用就行
##取分钟的随机数
def Minute():# 从1到60之间取一个随机数value = (random.uniform(1, 60))# .0代表后面的小数位为0个value = format(value, '.0f')return value##取描述的随机值
def Second():# 从1到60之间取一个随机数value = (random.uniform(1, 60))# .0代表后面的小数位为0个value = format(value, '.0f')return value
modifyFileTime函数的编写
##修改文件日期
def modifyFileTime(filePath, createTime, modifyTime, accessTime, offset):"""用来修改任意文件的相关时间属性,时间格式:YYYY-MM-DD HH:MM:SS 例如:2019-02-02 00:01:02:param filePath: 文件路径名:param createTime: 创建时间:param modifyTime: 修改时间:param accessTime: 访问时间:param offset: 时间偏移的秒数,tuple格式,顺序和参数时间对应"""try:format = "%Y-%m-%d %H:%M:%S" # 时间格式cTime_t = timeOffsetAndStruct(createTime, format, offset[0])mTime_t = timeOffsetAndStruct(modifyTime, format, offset[1])aTime_t = timeOffsetAndStruct(accessTime, format, offset[2])fh = CreateFile(filePath, GENERIC_READ | GENERIC_WRITE, 0, None, OPEN_EXISTING, 0, 0)createTimes, accessTimes, modifyTimes = GetFileTime(fh)createTimes = Time(time.mktime(cTime_t))accessTimes = Time(time.mktime(aTime_t))modifyTimes = Time(time.mktime(mTime_t))SetFileTime(fh, createTimes, accessTimes, modifyTimes)CloseHandle(fh)return 0except:return 1def timeOffsetAndStruct(times, format, offset):return time.localtime(time.mktime(time.strptime(times, format)) + offset)
来看看整体的代码效果
#!/usr/bin/env python
# -*- coding: utf-8 -*-import random
import tkinter as tk
import os
from win32file import CreateFile, SetFileTime, GetFileTime, CloseHandle
from win32file import GENERIC_READ, GENERIC_WRITE, OPEN_EXISTING
from pywintypes import Time
import time
import datetimeroot = tk.Tk() # 创建窗口对象
root.title("指定目录下文件时间批量修改 -----文件辅助程序 v2.10 ")
root.geometry("550x300")##修改文件日期
def modifyFileTime(filePath, createTime, modifyTime, accessTime, offset):"""用来修改任意文件的相关时间属性,时间格式:YYYY-MM-DD HH:MM:SS 例如:2019-02-02 00:01:02:param filePath: 文件路径名:param createTime: 创建时间:param modifyTime: 修改时间:param accessTime: 访问时间:param offset: 时间偏移的秒数,tuple格式,顺序和参数时间对应"""try:format = "%Y-%m-%d %H:%M:%S" # 时间格式cTime_t = timeOffsetAndStruct(createTime, format, offset[0])mTime_t = timeOffsetAndStruct(modifyTime, format, offset[1])aTime_t = timeOffsetAndStruct(accessTime, format, offset[2])fh = CreateFile(filePath, GENERIC_READ | GENERIC_WRITE, 0, None, OPEN_EXISTING, 0, 0)createTimes, accessTimes, modifyTimes = GetFileTime(fh)createTimes = Time(time.mktime(cTime_t))accessTimes = Time(time.mktime(aTime_t))modifyTimes = Time(time.mktime(mTime_t))SetFileTime(fh, createTimes, accessTimes, modifyTimes)CloseHandle(fh)return 0except:return 1def timeOffsetAndStruct(times, format, offset):return time.localtime(time.mktime(time.strptime(times, format)) + offset)##取分钟的随机数def Minute():# 从1到60之间取一个随机数value = (random.uniform(1, 60))# .0代表后面的小数位为0个value = format(value, '.0f')return value##取描述的随机值
def Second():# 从1到60之间取一个随机数value = (random.uniform(1, 60))# .0代表后面的小数位为0个value = format(value, '.0f')return valuedef fileChansTime(year,month,day,hour,path):####循环file_list = os.listdir(path)for file_name in file_list:print(file_name)minute = Minute()second = Second()##修改文件创建时间o = str(year) +"-" + str(month) + "-" + str(day) +" " + str(hour) + ":" + str(minute) + ":" + str(second)cTime = o # 创建时间mTime = o # 修改时间aTime = o # 访问时间# 文件路径,文件存在才能成功(可以写绝对路径,也可以写相对路径)offset = (0, 10, 30) # 偏移的秒数A = path + "\\" + file_nameprint(A)# 调用函数修改文件创建时间,并判断是否修改成功r = modifyFileTime(A, cTime, mTime, aTime, offset)if r == 0:print('修改完成')text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, file_name+"编辑时间的随机分钟和秒数已经更改成功")elif r == 1:text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, file_name+"编辑时间的随机分钟和秒数更改失败,请手动更改")def Start():#获取当天日期TIME = datetime.datetime.now()year = int(TIME.strftime("%Y")) #当前年份month = int(TIME.strftime("%m")) ###当前月day = int(TIME.strftime("%d")) ###当前天hour = int(TIME.strftime("%H")) ####当前时text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, "当前时间已经生成。。。。。。。。")####模板目录path = "D:\\wenjian"####循环文件,并进行批量更改text.insert(tk.INSERT, '\n')text.insert(tk.INSERT, "正在处理文件,请稍等。。。。。。。。")# findfile(path)###批量更改fileChansTime(year,month,day,hour,path)# 显示当前进行的操作,以及提示
jg = tk.LabelFrame(root,text="当前进展展示",padx=5,pady=5)
jg.grid(row=0,columnspan=2,sticky='w',padx=10,pady=10)text=tk.Text(jg,width=70,height=15)
scroll=tk.Scrollbar(jg)
scroll.grid(row=0,column=1)
text.grid(row=0,column=0)
scroll.config(command=text.yview)
text.config(yscrollcommand=scroll.set)tk.Button(root, text="文件时间修改", width=25, command=Start).grid(row=1,columnspan=2,padx=10, pady=10) # s南边也就是下边root.mainloop() # 进入消息循环
结束语
工作上终于不是那么忙了,以后有时间写自己的博客了,自己也是看到需要什么就写什么,希望可以帮助到大家,再次感谢大家的阅读,谢谢。
相关文章:
windows系统下利用python对指定文件夹下面的所有文件的创建时间进行修改
windows系统下利用python对指定文件夹下面的所有文件的创建时间进行修改 不知道其他的朋友们有没有这个需求哈,反正咱家是有这个需求 需求1、当前有大量的文件需要更改文件生成的时间,因为不可告知的原因,当前的文件创建时间是不能满足使用的…...
线性表的链式表示——单链表;头插,尾插,按值查找,按序号查找,插入,删除;
#include <iostream> #include <algorithm>//fill() #define InitSize 5using namespace std;/*线性表:链式表示——单链表;头插,尾插,按值查找,按序号查找,插入,删除*/ typedef st…...
【Spring Cloud系统】- Zookeer特性与使用场景
【Spring Cloud系统】- Zookeer特性与使用场景 一、概述 Zookeeper是一个分布式服务框架,是Apache Hadoop的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题。如:统一命名服务、状态同步服务、集群管理、分布式应用配置…...
最新AI智能创作系统源码SparkAi系统V2.6.3/AI绘画系统/支持GPT联网提问/支持Prompt应用/支持国内AI模型
一、智能AI创作系统 SparkAi创作系统是基于OpenAI很火的ChatGPT进行开发的Ai智能问答系统,已支持OpenAIGPT全模型国内AI全模型,已支持国内AI模型 百度文心一言、微软Azure、阿里云通义千问模型、清华智谱AIChatGLM、科大讯飞星火大模型等。本期针对源码…...
R | R包默认安装路径的查看及修改
R | R包默认安装路径的查看及修改 一、R包安装位置查看二、已安装R包查询三、R包安装位置修改四、R包安装位置永久修改 在【R: R package安装的几种方式】【R: R版本更新及R包迁移(详细步骤)】两篇文章中介绍过R包的常见安装方式,以及在不同R…...
将conda虚拟环境打包并集成到singularity镜像中
1. 使用yml文件打包 conda activate your_env conda env export > environment.yml编写cond.def文件 Bootstrap: dockerFrom: continuumio/miniconda3%filesenvironment.yml%post/opt/conda/bin/conda env create -f environment.yml%runscriptexec /opt/conda/envs/$(hea…...
Android Studio 是如何和我们的手机共享剪贴板的
背景 近期完成了target33的项目适配升级,随着AGP和gradle的版本升级,万年老版本Android Studio(后文简称AS)也顺便升级到了最新版Android Studio Giraffe | 2022.3.1,除了新UI外,最让我好奇的是这次的Running Devices功能(官方也称为Device mirroring)可以控制真机了. 按照操…...
大数据面试题:Spark和MapReduce之间的区别?各自优缺点?
面试题来源: 《大数据面试题 V4.0》 大数据面试题V3.0,523道题,679页,46w字 可回答: 1)spark和maprecude的对比;2)mapreduce与spark优劣好处 问过的一些公司:阿里云…...
【开发篇】十八、SpringBoot整合ActiveMQ
文章目录 1、安装ActiveMQ2、整合3、发送消息到队列4、使用消息监听器对消息队列监听5、流程性业务消息消费完转入下一个消息队列6、发布订阅模型 1、安装ActiveMQ docker安装 docker pull webcenter/activemqdocker run -d --name activemq -p 61616:61616 -p 8161:8161 webce…...
QTcpSocket 接收数据实时性问题
一、开发背景 使用 Qt 的 QTcpSocket 接收数据的时候发现数据接收出现粘包的现象,并且实时性很差,通过日志的时间戳发现数据接收的误差在 100ms 以内。 二、开发环境 Qt5.12.2 QtCreator4.8.2 三、实现步骤 在 socket 连接的槽函数设置接收延时时间&…...
前端el-select 单选和多选
el-select单选 <el-form-item label"部门名称" prop"departId"><el-select v-model"dataForm.departId" placeholder"请选择" clearable:style{ "width": "100%" } :multiple"false" filtera…...
【MySQL】Linux 中 MySQL 环境的安装与卸载
文章目录 Linux 中 MySQL 环境的卸载Linux 中 MySQL 环境的安装 Linux 中 MySQL 环境的卸载 在安装 MySQL 前,我们需要先将系统中以前的环境给卸载掉。 1、查看以前系统中安装的 MySQL rpm -qa | grep mysql2、卸载这些 MySQL rpm -qa | grep mysql | args yum …...
机器学习算法分类
学习视频黑马程序员 监督学习 无监督学习 半监督学习 强化学习...
Mysql bin-log日志恢复数据与物理备份-xtrabackup
主打一个数据备份与恢复 binlog与xtarbackup bin-log日志恢复开启bin-log配置bin-log日志恢复 物理备份-xtrabackup三种备份方式安装xtrabackup备份全量备份增量备份差异备份 bin-log日志恢复 bin-log 日志,就记录对数据库进行的操作,什么增删改的操作全…...
JAVA 学习笔记 2年经验
文章目录 基础String、StringBuffer、StringBuilder的区别jvm堆和栈的区别垃圾回收标记阶段清除阶段 异常类型双亲委派机制hashmap和hashtable concurrentHashMap 1.7和1.8的区别java的数据结构排序算法,查找算法堆排序 ThreadLocal单例模式常量池synchronizedsynch…...
网络安全--安全认证、IPSEC技术
目录 1. 什么是数据认证,有什么作用,有哪些实现的技术手段? 2. 什么是身份认证,有什么作用,有哪些实现的技术手段? 3. 什么是VPN技术? 4. VPN技术有哪些分类? 5. IPSEC技术能够…...
Mysql——创建数据库,对表的创建及字段定义、数据录入、字段增加及删除、重命名表。
一.创建数据库 create database db_classics default charsetutf8mb4;//创建数据库 use db_classics;//使用该数据库二.对表的创建及字段定义 create table if not exists t_hero ( id int primary key auto_increment, Name varchar(100) not null unique, Nickname varchar(1…...
第1篇 目标检测概述 —(4)目标检测评价指标
前言:Hello大家好,我是小哥谈。目标检测评价指标是用来衡量目标检测算法性能的指标,可以分为两类,包括框级别评价指标和像素级别评价指标。本节课就给大家重点介绍下目标检测中的相关评价指标及其含义,希望大家学习之后…...
前端和后端是Web开发中的两个不同的领域,你更倾向于哪一种?
前端和后端是Web开发中的两个不同的领域,你更倾向于哪一种? 你可以从以下几个维度谈谈你对前端开发和后端开发的看法。此为内容创作模板,在发布之前请将不必要的内容删除 一、引言 提示:可对前端开发和后端开发进行简要介绍并提出…...
SpringBoot集成MyBatis-Plus实现增删改查
背景 因为学习工具的时候经常需要用到jar包,需要增删查改接口,所以参考文章实现了基于mybatis-plus的增删查改接口。 参考文章:第二十二节:SpringBoot集成MyBatis-Plus实现增删改查 原文中的git地址不存在,本文内容是原文代码修…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
51c自动驾驶~合集58
我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留,CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制(CCA-Attention),…...
大型活动交通拥堵治理的视觉算法应用
大型活动下智慧交通的视觉分析应用 一、背景与挑战 大型活动(如演唱会、马拉松赛事、高考中考等)期间,城市交通面临瞬时人流车流激增、传统摄像头模糊、交通拥堵识别滞后等问题。以演唱会为例,暖城商圈曾因观众集中离场导致周边…...
解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八
现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet,点击确认后如下提示 最终上报fail 解决方法 内核升级导致,需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...
如何将联系人从 iPhone 转移到 Android
从 iPhone 换到 Android 手机时,你可能需要保留重要的数据,例如通讯录。好在,将通讯录从 iPhone 转移到 Android 手机非常简单,你可以从本文中学习 6 种可靠的方法,确保随时保持连接,不错过任何信息。 第 1…...
学习STC51单片机31(芯片为STC89C52RCRC)OLED显示屏1
每日一言 生活的美好,总是藏在那些你咬牙坚持的日子里。 硬件:OLED 以后要用到OLED的时候找到这个文件 OLED的设备地址 SSD1306"SSD" 是品牌缩写,"1306" 是产品编号。 驱动 OLED 屏幕的 IIC 总线数据传输格式 示意图 …...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
Java面试专项一-准备篇
一、企业简历筛选规则 一般企业的简历筛选流程:首先由HR先筛选一部分简历后,在将简历给到对应的项目负责人后再进行下一步的操作。 HR如何筛选简历 例如:Boss直聘(招聘方平台) 直接按照条件进行筛选 例如:…...
Android 之 kotlin 语言学习笔记三(Kotlin-Java 互操作)
参考官方文档:https://developer.android.google.cn/kotlin/interop?hlzh-cn 一、Java(供 Kotlin 使用) 1、不得使用硬关键字 不要使用 Kotlin 的任何硬关键字作为方法的名称 或字段。允许使用 Kotlin 的软关键字、修饰符关键字和特殊标识…...
【JVM面试篇】高频八股汇总——类加载和类加载器
目录 1. 讲一下类加载过程? 2. Java创建对象的过程? 3. 对象的生命周期? 4. 类加载器有哪些? 5. 双亲委派模型的作用(好处)? 6. 讲一下类的加载和双亲委派原则? 7. 双亲委派模…...
