Python文件的属性获取,重命名,目录的创建,显示和改变

简介: Python文件的属性获取,重命名,目录的创建,显示和改变

1. 文件的属性获取

os.stat()函数可以获取文件的属性,该函数会返回一个和系统平台有关的stat_result对象,

具备一组可访问的属性,可以通过 stat_result.attribute 这样的格式来访问各个属性的值。

字 段 描 述
st_mode inode 保护模式
st_ino inode节点号
st_dev inode驻留的设备
st_nlink inode的链接数
st_uid 所有者的用户 ID
st_gid 所有者的组 ID
st_size 普通文件以字节为单位的大小,包含等待某些特殊文件的数据
st_atime 上次访问的时间
st_mtime 最后一次修改的时间
st_ctime 由操作系统报告的 ctime。在某些系统上(如 UNIX)是最新的元数据更改的时间,在其他系统上(如 Windows)是创建时间

例如:

os.path也有许多函数可以获取文件的属性。

os.path的常用函数

函数名 功能
os.path.exists(path) 它用于判断当前的目录或者文件是否存在,如果存在,则返回 True,否则返回 False。
os.path.abspath(path) 返回指定文件或目录的绝对路径。
os.path.isabs(path) 判断路径是否为绝对路径,如果是则返回 True,否则返回 False。
os.path.isfile(path) 判断 path 是否是文件,如果是则返回 True,否则返回 False。
os.path.isdir(path) 判断 path 是否是目录,如果是则返回 True,否则返回 False。
os.path.getsize(path) 返回文件或者目录的大小,单位是字节。如果 name 是目录,则返回 0L;如果 name 代表的目录或文件不存在,则会报 WindowsError 异常。
os.path.normpath(path) 把 path 转换为标准的路径,用于解决跨平台问题
os.path.split(path) 对文件路径进行分割,把最后一个“\”后面的文件从目录分割出来。它将 path分割成目录和文件名(事实上,如果提供一个不带文件名的参数(纯目录形式),它也会将最后一个目录作为文件名而分离,而不会判断文件或目录是否存在),并存于元组中返回,
os.path.dirname(path) 返回目录的名称,即返回 path 的目录路径,其实就是 os.path.split(path)的第一个元素。
os.path.basename(path) 返回文件的名称,即返回 path 最后的文件名。如果 path 以“/”或“\”结尾,则返回空值,即 os.path.split(path)的第二个元素。
os.path.splitext(path) 把路径和扩展名切分开。路径和扩展名被分开后可以直接赋值给两个变量,其实得到的是一个元组。
os.path.splitdrive(path) 拆分驱动器(盘符)和后面的文件路径,并以元组返回结果;主要针对 Windows有效,Linux 元组第一个元素总是空;返回结果是元组。
os.path.join(path,*paths) 把所有的路径组合成绝对路径。连接两个或更多的路径名,中间以“\”分隔,如果所给的参数都是绝对路径名,则最先给的绝对路径将会被丢弃

部分举例如下:

2. 文件重命名

在Python中用 rename()方法来实现文件的重命名

语法:

os.rename(当前的文件名, 新的文件名)

例:

3. 目录的创建

在Python中用 mkdir()方法用于在当前目录下创建新的目录

语法:

os.mkdir(目录名)

Python 用 os.makedirs()方法实现递归创建目录,类似 mkdir(),但创建的所有中级文件夹需要包含子目录。

语法:

os.makedirs(需要递归创建的目录 [,权限模式])

权限模式,需要 8 进制数字,默认模式为 0o777。每个 7 代表了 3 位值为 1 的二进

制位,分别对应属主、同组用户和其他用户的 rwx(读、写、执行)权限。

例:

import os
path = "D:\\test\\test1\\test1-1\\test1-1-1"
os.makedirs(path,0o755)

截图中的sys模块可加可不加

4. 显示和改变

getcwd()方法用于显示当前的工作目录。

例如:

import os 
print(os.getcwd())

chdir()方法用于改变当前的目录。类似于Linux中的cd命令

例如,进入"/test/test1"目录:

import os
os.chdir("/test/test1") 

5. 运行系统命令

os.system()函数用于直接执行操作系统 Shell 命令,以字符串形式将命令传入,然后在函数中调用操作系统的 API,从而实现一个和 Shell 命令等价的操作。如果命令运行成功且正常结束,则返回状态代码 0。

例:

import os
os.system('dir')

感谢大家的支持,关注,评论,点赞!

94

目录
相关文章
|
2月前
|
编译器 Python
如何利用Python批量重命名PDF文件
本文介绍了如何使用Python提取PDF内容并用于文件重命名。通过安装Python环境、PyCharm编译器及Jupyter Notebook,结合tabula库实现PDF数据读取与处理,并提供代码示例与参考文献。
|
2月前
|
编译器 Python
如何利用Python批量重命名文件
本文介绍了如何使用Python和PyCharm对文件进行批量重命名,包括文件名前后互换、按特定字符调整顺序等实用技巧,并提供了完整代码示例。同时推荐了第三方工具Bulk Rename Utility,便于无需编程实现高效重命名。适用于需要处理大量文件命名的场景,提升工作效率。
|
3月前
|
编解码 Prometheus Java
当Python同时操作1000个文件时,为什么你的CPU只用了10%?
本文介绍如何构建一个高效的文件处理系统,解决单线程效率低、多线程易崩溃的矛盾。通过异步队列与多线程池结合,实现任务调度优化,提升I/O密集型操作的性能。
63 4
|
2月前
|
数据采集 监控 算法
Python文件与目录比较全攻略:从基础操作到性能优化
文件比较的核心在于数据指纹校验,通过逐字节比对生成唯一标识,确保内容一致性。从标准库的os与filecmp到高性能第三方库如pydiffx,再到分布式与量子加密技术的未来趋势,文件比较广泛应用于数据备份、代码审查与系统监控等领域,是保障数据完整性的关键技术手段。
68 0
|
3月前
|
数据采集 存储 API
Python爬虫结合API接口批量获取PDF文件
Python爬虫结合API接口批量获取PDF文件
|
3月前
|
数据采集 运维 BI
Python 文件操作进阶|使用 shutil 实现高效文件复制
在开发和运维中,处理大量文件是常见需求,如备份配置、归档日志或构建部署包。手动复制粘贴已无法满足高效需求!Python 的 `shutil` 模块提供了强大的文件操作功能,支持单文件复制、目录树迁移及自动化任务构建。本文详解 `shutil.copy()` 基础用法与进阶技巧,如批量复制、自动路径检测、时间戳命名备份等,助你实现高效自动化。结合实战案例(如自动备份系统),让你的代码更专业!学习后,欢迎交流心得,一起精进 Python 技能。关注我,获取更多编程技巧与源码分享!
|
6月前
|
机器学习/深度学习 存储 设计模式
Python 高级编程与实战:深入理解性能优化与调试技巧
本文深入探讨了Python的性能优化与调试技巧,涵盖profiling、caching、Cython等优化工具,以及pdb、logging、assert等调试方法。通过实战项目,如优化斐波那契数列计算和调试Web应用,帮助读者掌握这些技术,提升编程效率。附有进一步学习资源,助力读者深入学习。
|
3月前
|
Python
Python编程基石:整型、浮点、字符串与布尔值完全解读
本文介绍了Python中的四种基本数据类型:整型(int)、浮点型(float)、字符串(str)和布尔型(bool)。整型表示无大小限制的整数,支持各类运算;浮点型遵循IEEE 754标准,需注意精度问题;字符串是不可变序列,支持多种操作与方法;布尔型仅有True和False两个值,可与其他类型转换。掌握这些类型及其转换规则是Python编程的基础。
195 33
|
2月前
|
数据采集 分布式计算 大数据
不会Python,还敢说搞大数据?一文带你入门大数据编程的“硬核”真相
不会Python,还敢说搞大数据?一文带你入门大数据编程的“硬核”真相
69 1

推荐镜像

更多