自动化办公-Python-os模块的使用
os.path 模块的使用
在指定文件路径时,由于操作系统的差异,直接使用硬编码的路径可能会导致程序在不同平台上无法正常运行。为了解决这个问题,Python 提供了 os.path 模块,它包含了一系列用于路径操作的函数,可以帮助您以跨平台的方式处理文件路径。
为什么要使用 os.path 模块?
-
跨平台兼容性:不同的操作系统使用不同的路径分隔符,例如 Windows 使用反斜杠
\,而 Unix/Linux 和 macOS 使用正斜杠/。os.path模块会根据运行时的操作系统自动选择合适的路径分隔符。 -
简化路径操作:提供了丰富的函数用于路径拼接、分割、规范化等操作,避免手动处理路径字符串带来的错误。
os.path 模块的常用函数
-
os.path.join()-
功能:以正确的路径分隔符将一个或多个路径组件组合起来,形成一个完整的路径。
-
用法:
import os# 正确的用法 file_path = os.path.join('folder', 'example.txt') print(file_path) # 在 Windows 上输出 'folder\example.txt',在 Unix/Linux 上输出 'folder/example.txt'# 错误的用法(硬编码路径分隔符) file_path = 'folder/example.txt' # 在 Windows 上可能无法正确访问文件
-
-
os.path.abspath()-
功能:将相对路径转换为绝对路径。
-
用法:
import osrelative_path = 'folder/example.txt' absolute_path = os.path.abspath(relative_path) print(absolute_path) # 输出完整的绝对路径
-
-
os.path.dirname()和os.path.basename()-
功能:
os.path.dirname():获取路径中的目录部分。os.path.basename():获取路径中的文件名部分。
-
用法:
import ospath = '/home/user/documents/example.txt'directory = os.path.dirname(path) filename = os.path.basename(path)print(directory) # 输出 '/home/user/documents' print(filename) # 输出 'example.txt'
-
-
os.path.exists()-
功能:判断指定的路径是否存在。
-
用法:
import ospath = 'folder/example.txt'if os.path.exists(path):print('路径存在。') else:print('路径不存在。')
-
-
os.path.splitext()-
功能:将路径拆分为文件名和扩展名。
-
用法:
import ospath = 'folder/example.txt'root, ext = os.path.splitext(path) print(root) # 输出 'folder/example' print(ext) # 输出 '.txt'
-
-
os.path.split()-
功能:将路径拆分为目录和文件名。
-
用法:
import ospath = '/home/user/documents/example.txt'head, tail = os.path.split(path) print(head) # 输出 '/home/user/documents' print(tail) # 输出 'example.txt'
-
-
os.path.normpath()-
功能:规范化路径,消除冗余的分隔符和上层目录引用。
-
用法:
import ospath = 'folder//subfolder/../example.txt' normalized_path = os.path.normpath(path) print(normalized_path) # 输出 'folder/example.txt'
-
-
os.path.isabs()-
功能:判断路径是否为绝对路径。
-
用法:
import osprint(os.path.isabs('/home/user')) # 在 Unix/Linux 上返回 True print(os.path.isabs('C:\\Windows')) # 在 Windows 上返回 True
-
-
os.path.relpath()-
功能:计算从指定起始路径到目标路径的相对路径。
-
用法:
import ospath = '/home/user/documents/example.txt' start = '/home/user/'relative_path = os.path.relpath(path, start) print(relative_path) # 输出 'documents/example.txt'
-
处理操作系统差异
-
路径分隔符:
-
Windows:使用反斜杠
\,但在字符串中需要使用双反斜杠\\或者使用原始字符串r''。path = 'C:\\folder\\example.txt' # 或者 path = r'C:\folder\example.txt' -
Unix/Linux 和 macOS:使用正斜杠
/。
-
-
路径拼接:
-
推荐:使用
os.path.join()。import ospath = os.path.join('folder', 'subfolder', 'example.txt')
-
-
避免硬编码路径:不要直接在代码中写死完整的路径,应该使用相对路径或者配置文件。
使用示例
示例 1:跨平台的文件读取
import os# 获取当前脚本所在的目录
current_dir = os.path.dirname(os.path.abspath(__file__))# 拼接文件路径
file_path = os.path.join(current_dir, 'data', 'example.txt')# 读取文件内容
with open(file_path, 'r', encoding='utf-8') as f:content = f.read()print(content)
示例 2:检查文件或目录是否存在
import ospath = os.path.join('folder', 'example.txt')if os.path.isfile(path):print('这是一个文件。')
elif os.path.isdir(path):print('这是一个目录。')
else:print('路径不存在。')
示例 3:创建多级目录
import ospath = os.path.join('folder', 'subfolder')# 创建目录(如果目录不存在)
if not os.path.exists(path):os.makedirs(path)print('目录已创建。')
else:print('目录已存在。')
注意事项
-
避免硬编码路径分隔符:不要直接在路径中使用
'/'或'\',应该使用os.path.join()。# 错误的做法 path = 'folder/subfolder/example.txt' # 在 Windows 上可能出错# 正确的做法 path = os.path.join('folder', 'subfolder', 'example.txt') -
使用绝对路径:在需要明确指定文件位置时,使用绝对路径可以避免相对路径带来的不确定性。
import osabsolute_path = os.path.abspath('folder/example.txt') -
处理路径中的特殊字符:如果路径中包含空格、Unicode 字符等特殊字符,确保字符串编码正确,或使用原始字符串。
path = r'C:\Program Files\Example\example.txt' -
文件编码:在读取或写入文本文件时,明确指定编码格式(如
utf-8),以避免编码错误。with open(file_path, 'r', encoding='utf-8') as f:content = f.read() -
异常处理:在进行文件操作时,使用
try...except块捕获可能出现的异常,如文件未找到、权限不足等。try:with open(file_path, 'r', encoding='utf-8') as f:content = f.read() except FileNotFoundError:print('文件未找到。') except PermissionError:print('没有权限访问该文件。') except Exception as e:print(f'发生错误:{e}')
总结
-
os.path模块是处理文件路径的强大工具,可以帮助您编写跨平台的 Python 程序。 -
始终使用
os.path.join()等函数来拼接路径,以确保程序在不同操作系统上都能正确运行。 -
注意文件操作的异常处理和编码问题,以提高程序的健壮性和兼容性。
-
养成良好的编程习惯,避免硬编码路径和路径分隔符,使用相对路径或配置文件管理文件路径。
如果您对 os.path 模块的使用有任何疑问,或者需要进一步的示例和解释,请随时提问!
相关文章:
自动化办公-Python-os模块的使用
os.path 模块的使用 在指定文件路径时,由于操作系统的差异,直接使用硬编码的路径可能会导致程序在不同平台上无法正常运行。为了解决这个问题,Python 提供了 os.path 模块,它包含了一系列用于路径操作的函数,可以帮助您…...
无人机之数据处理技术篇
一、数据采集 无人机通过搭载的各种传感器和设备,如GPS、加速度计、陀螺仪、磁力计、激光雷达(LiDAR)、高光谱相机(Hyperspectral)、多光谱相机(Multispectral)以及普通相机等,实时采集飞行过程中的各种数据。这些数据包括无人机的位置、速度、高度、姿态…...
828华为云征文|部署多功能集成的协作知识库 AFFiNE
828华为云征文|部署多功能集成的协作知识库 AFFiNE 一、Flexus云服务器X实例介绍二、Flexus云服务器X实例配置2.1 重置密码2.2 服务器连接2.3 安全组配置2.4 Docker 环境搭建 三、Flexus云服务器X实例部署 AFFiNE3.1 AFFiNE 介绍3.2 AFFiNE 部署3.3 AFFiNE 使用 四、…...
c++(AVL树及其实现)
一、AVL树的概念 AVL树是最先发明的自平衡⼆叉查找树,AVL是⼀颗空树,或者具备下列性质的⼆叉搜索树:它的 左右子树都是AV树,且左右子树的高度差的绝对值不超过1。AVL树是⼀颗高度平衡搜索⼆叉树, 通过控制高度差去控…...
Cesium GIS项目关于湖泊识别与提取的实现
1. 引言 项目背景 随着遥感技术的发展,地理信息系统的应用越来越广泛。本项目旨在开发一个基于Cesium的地理信息系统,利用深度学习技术自动识别并显示湖泊的位置。 目标与意义 通过自动化处理大量遥感影像数据,提高湖泊监测的效率和准确性,为水资源管理和环境保护提供支…...
两个圆形 一个z里面一个z外面,z里面的大,颜色不同 html
两个圆形 一个z里面一个z外面,z里面的大,颜色不同 html <!DOCTYPE html> <html> <head> <style> .outer-circle {width: 150px;height: 150px;border-radius: 50%;background-color: #ff9999; /* 外圆的颜色 */position: relat…...
【Power Query】M函数-table
M函数-table 添加列(AddColumn):条件语句(If..then..else):容错语句(try..otherwise): 排序(ReorderColumns):筛选(Selec…...
uni-app 封装websocket 心跳检测,开箱即用
class websocketUtils {constructor(url, needbeat, options {}) {this.needbeat needbeat;this.url url;this.options options;this.ws null;this.heartbeatInterval options.heartbeatInterval || 10000; // 心跳间隔,默认为10秒 this.reconnectInterval …...
ASP.NET Core8.0学习笔记(十九)——EF Core DbSet
一、DbSet概述 1.DbSet提供了通过DbContext对表进行查询操作的路径。DbSet对应的属性名称将默认映射为实体T的表名。 2.使用DbSet<T>进行查询的方法: (1)直接在DbContext中创建对应的DbSet<T>属性 (2)使用DbSet DbContext.Set<T>方法操作数据表。…...
Android Camera 预览角度和拍照保存图片角度相关
–基于Android R(11) 关于Camera Camera Framework 的架构 Android Camera Framework 是一个分层架构,由以下组件组成: HAL(硬件抽象层): HAL 抽象底层相机硬件,提供与不同设备相机进行交互的标准接口.CameraService : Camera…...
新手如何使用Qt——方法使用
前言 那么这篇文章其实是我在使用Qt的过程当中呢,我发现在Qt使用过程中,在我理解信号和槽这个概念后,在编写槽函数数的时候,发现了自身存在的问题,我的难点是在于当我在编写槽函数的时候,我知道这个槽函数是…...
友元运算符重载函数
目录 1.定义友元运算符重载函数的语法形式 2.双目运算符重载 3.单目运算符重载 1.定义友元运算符重载函数的语法形式 (1)在类的内部,定义友元运算符重载函数的格式如下: friend 函数类型 operator 运算符(形参表&a…...
从0开始实现es6 promise类
主要由基础实现和静态类的实现两部分组成。 1 基础实现(不含静态类) 1.1 使用类实现完成构造函数 实现代码如下,构造函数传入一个回调函数,定义resolve和reject函数,将两个函数作为参数执行回调函数。 // 1. 使用类实…...
XML 编码
XML 编码 XML(可扩展标记语言)是一种用于存储和传输数据的标记语言。它由万维网联盟(W3C)开发,旨在提供一种标准的方式来结构化、存储和传输数据。XML的设计目标是既易于人类阅读,也易于机器解析。 XML的…...
AI周报(9.22-9.28)
AI应用-Siipet宠物沟通师 Siipet是一款由SiiPet公司推出的创新宠物行为分析相机,旨在通过尖端技术加深宠物与主人之间的情感联系。这款相机利用先进的AI算法,能够自动识别和分析家中宠物的行为,并提供定制化的护理建议。 SiiPet相机的核心功…...
基于RealSense D435相机实现手部姿态重定向
基于Intel RealSense D435相机和MediaPipe的手部姿态检测,进一步简单实现手部姿态与机器人末端的重定向,获取手部的6D坐标(包括位置和姿态)。 假设已经按照【基于 RealSenseD435i相机实现手部姿态检测】配置好所需的库和环境&…...
js中防抖 debounce 节流 throttle 原理 从0手动实现
1 防抖 高频触发事件时,执行损耗高的操作,连续触发过程中,只执行最后一次。 高频事件:input scroll resize等。损耗高:网络请求、dom操作。 实现防抖步骤:1.在回调函数中判断timer是否存在,存在…...
AIGC: 10 AI转文服务器的搭建过程记录
上图是台风席卷城市,现在企业的服务基本都是混合部署,云计算厂商的机房往往可以提供比较好的保护,一般在地下,扛多少级地震,扛多少级台风,而自建机房,往往写字楼经常停电,网络运营上…...
性能测试1初步使用Jmeter
当你看到这边文章的时候,详细你已经知道啥是性能测试,以及也听说过Jmeter了,所以不过多介绍,这里,只是帮助你快速的使用Jmeter来测试接口。 1获取安装包 官网下载地址:https://jmeter.apache.org/downloa…...
OpenGL ES 绘制一个三角形(2)
OpenGL ES 绘制一个三角形(2) 简述 本节我们基于Android系统,使用OpenGL ES来实现绘制一个三角形。在OpenGL ES里,三角形是一个基础图形,其他的图形都可以使用三角形拼接而成,所以我们就的案例就基于这个开始。 在Android系统中…...
AI大模型入门必看:小白也能掌握的AI新风口,速收藏!
2026年AI,LLM彻底火出圈了,就连附近的早教中心,都易匾更名,叫“AI智习室”!那LLM究竟是啥? (一)什么是LLM? LLM 是 Large Language Model(大型语言模型)的缩写ÿ…...
从H5到uni-app:迁移‘滚动菜单高亮’功能时,我踩过的3个关键差异点
从H5到uni-app:迁移滚动菜单高亮功能的三大思维转换 第一次在uni-app里实现滚动菜单高亮效果时,我差点把键盘摔了——那些在H5里信手拈来的document.querySelector和window.scrollY突然全部失效。这就像习惯右手写字的人突然被要求用左手,明明…...
如何在Python中正确调用DeepSeek-Reasoner获取思考过程(附完整代码示例)
深度解析:Python调用DeepSeek-Reasoner获取思维链的工程实践 当开发者需要构建具备复杂推理能力的AI应用时,获取模型完整的思考过程(Reasoning Content)往往比最终答案更有价值。DeepSeek-Reasoner作为专为逻辑推理优化的模型&…...
DeepSeek-VL2微调报错“AssertionError”终极解决:修改config.json里的topk_method参数
DeepSeek-VL2微调报错"AssertionError"终极解决方案:深入解析topk_method参数 当你满怀期待地准备微调DeepSeek-VL2这个强大的多模态大模型时,却在训练启动阶段遭遇了令人沮丧的"AssertionError"和"assert not self.training&q…...
告别抢票焦虑:用Python自动化脚本轻松获取大麦网演唱会门票
告别抢票焦虑:用Python自动化脚本轻松获取大麦网演唱会门票 【免费下载链接】DamaiHelper 大麦网演唱会演出抢票脚本。 项目地址: https://gitcode.com/gh_mirrors/dama/DamaiHelper 还在为心仪的演唱会门票秒光而烦恼吗?DamaiHelper大麦网抢票脚…...
【Simulink】双矢量调制MPC在并网逆变器中的实现:从理论到仿真
1. 双矢量MPC为什么更适合并网逆变器控制 我第一次接触双矢量模型预测控制(MPC)是在调试一个光伏并网项目时。当时单矢量MPC的电流纹波始终达不到设计要求,直到看到郭磊磊老师那篇经典论文才恍然大悟——原来矢量组合方式才是破局关键。相比传…...
OpenCV图像拼接避坑指南:为什么你的特征点总是匹配失败?
OpenCV图像拼接避坑指南:为什么你的特征点总是匹配失败? 当你第一次尝试用OpenCV实现图像拼接时,可能会遇到一个令人沮丧的问题:明明按照教程一步步操作,特征点匹配的结果却惨不忍睹。要么匹配点对寥寥无几,…...
Qwen3.5-4B模型网络协议分析应用:模拟客户端与解析通信数据
Qwen3.5-4B模型网络协议分析应用:模拟客户端与解析通信数据 1. 网络协议分析的AI新思路 网络协议分析一直是运维工程师和安全研究人员的日常工作重点。传统方法需要人工查阅RFC文档、编写测试代码、分析抓包数据,整个过程耗时费力。Qwen3.5-4B模型的出…...
SAM3镜像部署:一键启动,开箱即用的文本引导分割工具
SAM3镜像部署:一键启动,开箱即用的文本引导分割工具 1. 快速入门指南 1.1 镜像概述 本镜像基于Meta最新发布的SAM3(Segment Anything Model 3)算法构建,通过二次开发集成了直观的Gradio Web交互界面。无需任何编程基…...
实战指南:用快马平台生成团队统一的homebrew环境配置脚本,保障协作无忧
最近在团队协作中遇到了一个头疼的问题:新成员加入时,光是搭建开发环境就要折腾一整天。不同成员的电脑上软件版本参差不齐,导致"在我机器上能跑"的经典问题频繁出现。经过一番摸索,我发现用homebrew配合bash脚本可以完…...
