Python 文件修改时间与创建时间读取

答案:在Python中可通过os.path和pathlib模块获取文件时间;1. 使用os.path.getmtime()获取修改时间;2. os.path.getctime()在Windows返回创建时间,Linux为inode更改时间;3. pathlib提供更现代语法,file_path.stat().st_mtime和st_ctime对应修改和创建时间;4. Linux不支持真实创建时间,建议优先使用修改时间,时间戳可转为datetime对象处理。

python 文件修改时间与创建时间读取

在 Python 中读取文件的创建时间和修改时间,可以通过 os.path 模块和 pathlib 模块实现。不同操作系统对“创建时间”的支持有所不同:Windows 支持创建时间,macOS 部分支持,而 Linux 通常不提供创建时间,只能获取修改时间。

1. 使用 os.path.getmtime() 获取修改时间

通过 os.path.getmtime() 可以获取文件的最后修改时间,返回的是时间戳(从 1970 年 1 月 1 日起的秒数):

import osimport time

file_path = 'example.txt'modify_time = os.path.getmtime(file_path)print("修改时间:", time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(modify_time)))

2. 使用 os.path.getctime() 获取创建时间

os.path.getctime() 在 Windows 上返回创建时间,在 Unix/Linux 上返回的是 inode 修改时间(不是创建时间):

create_time = os.path.getctime(file_path)print("创建时间:", time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(create_time)))

3. 使用 pathlib 更现代的方式

Python 3.4+ 推荐使用 pathlib,语法更清晰:

立即学习“Python免费学习笔记(深入)”;

from pathlib import Pathimport time

file_path = Path('example.txt')

修改时间

modify_time = file_path.stat().st_mtimeprint("修改时间:", time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(modify_time)))

创建时间(Windows 是创建时间)

create_time = file_path.stat().st_ctimeprint("创建时间:", time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(create_time)))

4. 注意事项

Linux 不记录文件的真正“创建时间”,所以 st_ctime 实际是状态更改时间。若需跨平台一致行为,建议优先依赖修改时间(st_mtime)。时间戳可转换为 datetime 对象以便进一步处理:

from datetime import datetime

dt_modify = datetime.fromtimestamp(modify_time)print("datetime 格式:", dt_modify)

基本上就这些。根据系统环境选择合适方法,注意平台差异即可。

以上就是Python 文件修改时间与创建时间读取的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1381990.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 23:30:17
下一篇 2025年12月14日 23:30:28

相关推荐

  • python日志库的模块化方法

    通过分层命名、配置分离和封装初始化逻辑实现Python日志模块化:1. 利用logging模块的层级结构,按模块命名(如app.main)统一管理日志级别;2. 将配置抽离至独立文件或模块,启动时加载,保持业务代码简洁;3. 封装setup_logger等工厂函数,统一处理handler、格式化和输…

    2025年12月14日
    000
  • 初学者用 VS Code 搭建 Python 环境的全流程

    答案是用VS Code搭建Python环境只需五步:安装Python并添加到PATH,下载VS Code,安装Python扩展,创建运行hello.py文件,最后配置解释器选择正确版本即可开始编程。 刚接触 Python 的新手常常被环境配置搞得一头雾水。其实用 VS Code 搭建 Python …

    2025年12月14日
    000
  • Python 将文件内容批量替换的脚本编写

    答案:该脚本通过遍历指定目录,匹配特定扩展名文件,执行多组字符串替换,并支持备份原文件。使用时需注意编码、测试范围及大文件处理。 在处理文本文件时,经常会遇到需要批量替换文件中某些内容的情况。比如修改配置项、更新路径或统一命名规则等。Python 提供了简单高效的方式来实现这一需求。下面是一个实用的…

    2025年12月14日
    000
  • python中property函数的功能是什么?

    property函数将方法包装为属性,实现对私有属性的访问控制;2. 可定义getter、setter和deleter,用于拦截属性的读取、赋值和删除操作;3. 支持在不改变接口的情况下加入数据验证或逻辑处理。 在Python中,property函数的作用是将类中的方法包装成属性,使得调用该方法时无…

    2025年12月14日
    000
  • Python 处理文件编码错误的解决方法

    先明确文件真实编码并显式指定。常见方法包括:1. 打开时用encoding参数指定gbk、utf-8等;2. 用chardet库自动检测编码;3. 设置errors=’ignore’或’replace’处理异常字符;4. 将文件统一转为UTF-8编码保…

    2025年12月14日
    000
  • python中列表的索引如何理解?

    列表索引用于访问元素,从0开始正向计数,-1起反向计数,如[‘apple’,’banana’,’cherry’]中索引1为’banana’,-1为’cherry’,越界则报错。 列…

    2025年12月14日
    000
  • 如何将python函数模块化?

    将Python函数模块化是通过创建.py文件封装相关函数,再用import导入使用,例如将add、multiply等函数存入math_utils.py文件,主程序通过import math_utils或from math_utils import add等方式调用;项目较大时可构建包,如创建util…

    2025年12月14日
    000
  • python如何实现工作表合并?

    答案:Python通过pandas库实现工作表合并,常用concat方法。首先读取多个Excel文件或Sheet页数据,依次添加到DataFrame中,可选择性加入来源标识列,最后统一保存为新Excel文件,适用于多文件或多Sheet的行向合并场景。 Python实现工作表合并主要通过 pandas…

    2025年12月14日
    000
  • python中pygal模块如何使用?

    Pygal是一个Python库,用于生成SVG格式的交互式图表。首先通过pip install pygal安装,然后导入图表类型如Bar、Line、Pie,创建实例并设置标题和标签,使用add()方法添加数据,x_labels设置横坐标,最后调用render_to_file()输出SVG文件。例如绘…

    2025年12月14日
    000
  • 如何使用py​thon3中的heapq模块?

    Python3的heapq模块提供最小堆操作,通过heappush、heappop和heapify函数对列表进行堆处理;可通过取负数模拟最大堆;支持nsmallest、nlargest等高效应用;自定义对象需实现__lt__方法以支持比较。 Python3中的heapq模块提供了对堆(最小堆)的基本…

    2025年12月14日
    000
  • Python 异常处理在文件操作中的应用

    答案:Python文件操作需通过异常处理应对文件不存在、权限不足等问题。常见异常包括FileNotFoundError、PermissionError、UnicodeDecodeError等,应使用try-except分层捕获,并结合finally确保资源释放。实际应用中建议提供恢复策略、多编码重试…

    2025年12月14日
    000
  • python字符串需要注意的语法问题

    掌握Python字符串需注意:1. 引号成对使用,嵌套时内外类型不同;2. 转义字符用反斜杠,路径建议用原始字符串;3. 拼接优先用f-string或join()提升效率;4. 索引越界会报错,切片则自动截断。 Python字符串看似简单,但在实际使用中容易因忽略细节导致错误。掌握以下几个关键语法问…

    2025年12月14日
    000
  • python psutil库有何用法?

    psutil 是跨平台 Python 库,用于监控系统资源,支持获取 CPU 使用率(psutil.cpu_percent(interval=1))、核心数(cpu_count)、CPU 时间(cpu_times);内存方面提供物理内存(virtual_memory)和交换分区(swap_memor…

    2025年12月14日
    000
  • python中pathlib模块的用法有哪些?

    pathlib提供面向对象的路径操作,支持创建路径、拼接、访问组件、判断属性、读写文件、遍历目录、管理目录及获取文件信息,相比os.path更直观且跨平台兼容。 pathlib 是 Python 3.4+ 引入的用于处理文件路径的标准库模块,提供面向对象的方式操作路径,比传统的 os.path 更直…

    2025年12月14日
    000
  • Python 布尔值与逻辑判断详解

    布尔值True和False是Python中控制流程的基础,用于条件判断和循环。它们属于bool类型且等价于1和0,可通过比较操作获得。逻辑运算符and、or、not用于组合或反转布尔表达式,并具有短路特性。在真值测试中,None、False、0、空序列等被视为False,其他对象通常为True。if…

    2025年12月14日
    000
  • Python 批量处理指定类型文件的方法

    使用glob、os.walk和pathlib可批量处理文件。1. glob通过通配符快速匹配如*.txt文件;2. os.walk遍历目录并用endswith筛选;3. pathlib提供面向对象的现代路径操作;按场景选择方法,结合异常处理,高效实现文件批量操作。 在日常开发或数据处理中,经常需要对…

    2025年12月14日
    000
  • 如何使用python中的optionparser模块?

    OptionParser属于optparse库,用于解析命令行参数。首先导入并创建实例:from optparse import OptionParser; parser = OptionParser()。通过add_option()添加选项,支持短格式(-v)和长格式(–verbose…

    2025年12月14日
    000
  • python如何求解线性方程组?

    最常用方法是使用numpy.linalg.solve()求解线性方程组,适用于系数矩阵可逆的情况,如A=[[2,1],[1,-1]]、b=[5,1]时,x=np.linalg.solve(A,b)得解[2.,1.];求解前应通过np.linalg.det(A)检查行列式是否非零以确保可逆;对于超定或…

    2025年12月14日
    000
  • Python之PyArmadillo计算库的产生

    PyArmadillo 是将 C++ Armadillo 库引入 Python 的高性能线性代数工具,1. 通过 Cython 或 pybind11 封装实现高效矩阵运算,2. 支持密集与稀疏矩阵并提供 MATLAB 风格语法,3. 填补 NumPy/SciPy 在大规模计算与 C++ 协同开发中的…

    2025年12月14日
    000
  • Python中NumPy的基本概念

    NumPy的核心是ndarray,一种高效处理多维数组和矩阵运算的对象,支持统一数据类型以提升性能;可通过np.array()、zeros、ones、arange、linspace等函数创建数组;关键属性包括shape、ndim、dtype和size;支持逐元素数学运算及广播机制,实现不同形状数组间…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信