Python os模块完全指南:轻松玩转文件管理与系统操作
wptr33 2025-06-15 19:46 21 浏览
Python os模块完全指南:轻松玩转文件管理与系统操作
os 模块是Python与操作系统对话的"瑞士军刀",学会它能让你轻松管理文件、操控路径、获取系统信息。本教程通过场景化案例+图解帮你快速上手,文末还有防坑指南哦!
一、文件与目录操作(动手试试!)
1. 定位当前位置:你的Python程序在哪?
import os
# 好比打开手机地图查看自己的位置
current_dir = os.getcwd()
print("你现在在这里:", current_dir) # 输出示例:C:\Users\小明\python_project
2. 查看文件夹内容:就像翻找书包
# 列出当前目录所有内容(包括隐藏文件)
items = os.listdir(".")
print("书包里有:", items) # 输出如:['笔记.docx', '照片', '作业.zip']
3. 创建/删除文件夹:建房子与拆积木
# 创建单层文件夹(只能建一层)
os.mkdir("新文件夹")
# 创建多层文件夹(自动建好每一层)
os.makedirs("年度报告/2023/第一季度")
# 删除空文件夹(必须保证里面没东西!)
os.rmdir("废弃的空文件夹")
# 危险操作:删除整个文件夹树(包括所有子文件)
import shutil # 需要额外导入这个工具包
shutil.rmtree("年度报告") # 慎用!删除后无法恢复
4. 文件操作:改名、删除、验身份
# 给文件改名(也可移动文件位置)
os.rename("旧名字.txt", "新名字.txt")
# 删除文件(送进回收站?不!直接永久删除)
os.remove("没用的文件.txt")
# 检查身份(是文件还是文件夹?)
print(os.path.isfile("报告.pdf")) # True
print(os.path.isdir("我的照片")) # True
二、路径管理(跨平台必备技能)
1. 智能拼接路径:自动适应不同系统
# 不用操心Windows用\,Linux用/
safe_path = os.path.join("文件夹", "子文件夹", "数据.csv")
print(safe_path) # Win输出:文件夹\子文件夹\数据.csv | Mac/Linux:文件夹/子文件夹/数据.csv
2. 拆解路径:轻松获取文件名和扩展名
# 拆分目录和文件名
directory, filename = os.path.split("/用户/小明/作业/数学.pdf")
print("目录:", directory) # /用户/小明/作业
print("文件名:", filename) # 数学.pdf
# 分离主文件名和扩展名
main_name, extension = os.path.splitext("风景照.jpg")
print("主文件名:", main_name) # 风景照
print("扩展名:", extension) # .jpg
3. 路径检测:避免文件失踪的秘籍
if os.path.exists("重要数据.xlsx"):
print("文件存在,可以操作!")
else:
print(" 文件找不到,检查路径是否正确!")
# 获取绝对路径(定位文件的完整地址)
abs_path = os.path.abspath("笔记.txt")
print("绝对路径:", abs_path) # 如:C:\Users\小明\笔记.txt
三、系统信息与操作(探索你的电脑)
1. 获取系统情报
print("操作系统类型:", os.name) # 'nt'代表Windows,'posix'代表Mac/Linux
print("路径分隔符:", os.sep) # Windows显示\,Mac/Linux显示/
print("当前登录用户:", os.getlogin()) # 输出:小明
# 查看环境变量(比如找Python安装路径)
print("系统PATH:", os.environ.get('PATH'))
2. 执行系统命令:让Python帮你敲命令
# 执行命令(就像在终端里输入一样)
status = os.system("dir") # Windows查看目录
# status = os.system("ls -l") # Mac/Linux查看详细列表
if status == 0:
print(" 命令执行成功!")
else:
print(" 出错了,检查命令是否正确")
四、实战案例:批量整理杂乱文件
场景:把"下载"文件夹里所有.txt文件按顺序命名为笔记1.txt, 笔记2.txt...
import os
download_folder = "下载"
counter = 1 # 起始编号
try:
for filename in os.listdir(download_folder):
# 只处理txt文件
if filename.endswith(".txt"):
# 构建新旧完整路径
old_path = os.path.join(download_folder, filename)
new_name = f"笔记{counter}.txt"
new_path = os.path.join(download_folder, new_name)
# 执行重命名
os.rename(old_path, new_path)
print(f"重命名成功:{filename} → {new_name}")
counter += 1
print(f" 整理完成!共处理了{counter-1}个文件")
except Exception as e:
print(f" 出错啦!原因:{str(e)}")
五、安全操作指南(新手必看!)
- 防误删三原则
o 操作前用os.path.exists()检查路径是否存在
o 删除前先打印要操作的文件路径确认
o 重要数据提前备份 - 跨平台兼容技巧
o 永远使用os.path.join()拼接路径
o 不要直接写C:\Users(Mac/Linux会出错)
o 检查系统类型:if os.name == 'nt': - 异常处理模板
try:
os.remove("重要文件.txt")
except FileNotFoundError:
print("文件不存在,请检查文件名")
except PermissionError:
print("没有删除权限!")
except Exception as e:
print("发生未知错误:", str(e))
知识拓展
官方文档:Python os模块文档
推荐练习:编写一个自动整理桌面文件的小工具(按扩展名分类到不同文件夹)
通过掌握这些技能,你已经能写出比Windows资源管理器更智能的文件管理程序了!遇到问题随时查阅文档,动手实践是学习编程的最佳途径~
相关推荐
- MySQL进阶五之自动读写分离mysql-proxy
-
自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...
- 3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?
-
引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...
- 一文由浅入深带你完全掌握MySQL的锁机制原理与应用
-
本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...
- 验证Mysql中联合索引的最左匹配原则
-
后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...
- MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)
-
目录1.索引基础...
- 你会看 MySQL 的执行计划(EXPLAIN)吗?
-
SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...
- MySQL 从入门到精通(四)之索引结构
-
索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...
- mysql总结——面试中最常问到的知识点
-
mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...
- mysql总结——面试中最常问到的知识点(2)
-
首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...
- MySQL基础全知全解!超详细无废话!轻松上手~
-
本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...
- 深入剖析 MySQL 中的锁机制原理_mysql 锁详解
-
在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...
- Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析
-
引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...
- MySQL基础篇:DQL数据查询操作_mysql 查
-
一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...
- MySql:索引的基本使用_mysql索引的使用和原理
-
一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
Java面试必考问题:什么是乐观锁与悲观锁
-
如何将AI助手接入微信(打开ai手机助手)
-
redission YYDS spring boot redission 使用
-
SparkSQL——DataFrame的创建与使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)