Python os.path() 模块

本文介绍了Python os.path模块的多种实用方法及其应用场景,包括获取文件名、路径、文件大小及时间等,并通过具体实例展示了如何使用这些方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

os.path 模块主要用于获取文件的属性

1.以下是 os.path 模块的几种常用方法:

方法说明
os.path.abspath(path)返回绝对路径
os.path.basename(path)返回文件名
os.path.commonprefix(list)返回list(多个路径)中,所有path共有的最长的路径
os.path.dirname(path)返回文件的文件夹路径(文件所在目录的绝对路径)
os.path.exists(path)如果路径 path 存在,返回 True;如果路径 path 不存在,返回 False。
os.path.lexists路径存在则返回True,路径损坏也返回True
os.path.expanduser(path)把path中包含的"~"和"~user"转换成用户目录
os.path.expandvars(path)根据环境变量的值替换path中包含的"$name"和"${name}"
os.path.getatime(path)返回最近访问时间(浮点型秒数)
os.path.getmtime(path)返回最近文件修改时间
os.path.getctime(path)返回文件 path 创建时间
os.path.getsize(path)返回文件大小,如果文件不存在就返回错误
os.path.isabs(path)判断是否为绝对路径
os.path.isfile(path)判断路径是否为文件
os.path.isdir(path)判断路径是否为目录
os.path.islink(path)判断路径是否为链接
os.path.ismount(path)判断路径是否为挂载点
os.path.join(path1[, path2[, ...]])把目录和文件名合成一个路径
os.path.normcase(path)转换path的大小写和斜杠
os.path.normpath(path)规范path字符串形式
os.path.realpath(path)返回path的真实路径
os.path.relpath(path[, start])从start开始计算相对路径
os.path.samefile(path1, path2)判断目录或文件是否相同
os.path.sameopenfile(fp1, fp2)判断fp1和fp2是否指向同一文件
os.path.samestat(stat1, stat2)判断stat tuple stat1和stat2是否指向同一个文件
os.path.split(path)把路径分割成 dirname 和 basename,返回一个元组
os.path.splitdrive(path)一般用在 windows 下,返回驱动器名和路径组成的元组
os.path.splitext(path)分割路径,返回路径名和文件扩展名的元组
os.path.splitunc(path)把路径分割为加载点与文件
os.path.walk(path, visit, arg)遍历path,进入每个目录都调用visit函数,visit函数必须有3个参数(arg, dirname, names),dirname表示当前目录的目录名,names代表当前目录下的所有文件名,args则为walk的第三个参数
os.path.supports_unicode_filenames设置是否支持unicode路径名

2.实例

2.1以下实例演示了 os.path 相关方法的使用:

# -*- coding: UTF-8 -*-
import os
 
print( os.path.basename('/root/runoob.txt') )   # 返回文件名
print( os.path.dirname('/root/runoob.txt') )    # 返回目录路径
print( os.path.split('/root/runoob.txt') )      # 分割文件名与路径
print( os.path.join('root','test','runoob.txt') )  # 将目录和文件名合成一个路径

执行以上程序输出结果为:

runoob.txt
/root
('/root', 'runoob.txt')
root/test/runoob.txt

2.2以下实例输出文件的相关信息

# -*- coding: UTF-8 -*-
import os
import time
 
file='/root/runoob.txt' # 文件路径
 
print( os.path.getatime(file) )   # 输出最近访问时间
print( os.path.getctime(file) )   # 输出文件创建时间
print( os.path.getmtime(file) )   # 输出最近修改时间
print( time.gmtime(os.path.getmtime(file)) )  # 以struct_time形式输出最近修改时间
print( os.path.getsize(file) )   # 输出文件大小(字节为单位)
print( os.path.abspath(file) )   # 输出绝对路径
print( os.path.normpath(file) )  # 规范path字符串形式

执行以上程序输出结果为:

1539052805.5735736
1539052805.5775735
1539052805.5735736
time.struct_time(tm_year=2018, tm_mon=10, tm_mday=9, tm_hour=2, tm_min=40, tm_sec=5, tm_wday=1, tm_yday=282, tm_isdst=0)
7
/root/runoob.txt
/root/runoob.txt

 

### 关于 Navicat Premium 16 定时导出导入的配置教程 Navicat Premium 16 提供了一种便捷的方式来实现数据库的定时导出导入操作。通过其内置的任务调度功能,可以轻松安排定期执行的数据传输、备份或其他自动化任务[^3]。 #### 配置定时导出/导入的方法 1. **打开“计划”窗口** 启动 Navicat Premium 16 并连接到目标数据库后,在顶部菜单栏中选择 `工具` -> `计划`,或者右键单击某个已建立的连接并选择 `新建计划`[^4]。 2. **创建新计划** 在弹出的对话框中点击 `新建` 按钮来定义一个新的计划任务。此时会出现一个向导界面,引导用户逐步完成任务的设定。 3. **选择任务类型** 当前支持多种任务类别,对于导出导入需求而言,应分别选取如下选项: - 导出:选择 “数据传输” 类型。 - 导入:同样可选 “数据传输”,只需调整源与目标的方向即可[^4]。 4. **指定数据范围** 接下来需明确哪些表或视图参与此次操作。可以通过勾选具体对象列表中的条目来进行精确控制;也可以采用通配符批量处理整个模式下的所有实体[^4]。 5. **设置存储路径** 对于导出作业来说,必须指明文件保存的位置及其格式(CSV, Excel, TXT 等)。而针对导入流程,则相反地需要提供原始资料所在地址以及匹配的目标结构[^4]。 6. **规划触发时间** 利用内嵌的日历控件配合时刻参数输入框,准确划定初次启动日期及时刻,并决定后续重复频率(每日、每周、每月或是自定义间隔)[^3]。 7. **高级属性定制** 如果必要的话,还可以进一步优化邮件通知机制、错误重试策略等方面的内容以增强可靠性。 8. **验证与激活** 最终审查各项参数无误之后提交确认,这样就成功建立了所期望的功能实例。记得启用开关使其生效[^4]。 ```bash # 示例命令行模拟手动测试脚本 (仅作参考用途) navicatcli --export source_db="my_database" target_file="/path/to/exported_data.csv" navicatcli --import source_file="/another/path/import_source.json" destination_table="new_records" ``` 以上便是利用 Navicat Premium 16 设置周期性数据迁移的基本步骤概述。实际应用当中可能还会涉及到更多细节考量因素,请参照官方文档获取最权威指导信息[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值