python文件操作常用方法整理23

简介: 【7月更文挑战第23天】python文件操作常用方法整理

一、删除文件夹下的所有文件

导入os库

通过os.listdir方法获取给定目录下的所有文件名,使用os.path.join方法循环拼接文件名和目录名,通过os.unlink方法删除指定的文件

• import os
• def deldirfile(download_dir):
• for filename in os.listdir(download_dir):
•         source_file_path = os.path.join(download_dir, filename)
•         os.unlink(source_file_path)

二、判断目录是否存在,不存在的创建目录

和上面的方法一样,导入os库,判断目录是否存在

通过os.mkdir方法创建目录

• if not os.path.isdir(target_directory):
•   os.mkdir(target_directory)

三、判断文件名是否是指定的扩展名文件是否存在

通过os.endswith()方法判断是否以指定的文件后缀结束,这里判断的是否为.docx文件,也就是word文件。

• if filename.endswith(".docx"):
•   target_file_path = os.path.join(target_directory, filename)

四、判断文件是否哦存在,存在则删除文件

os.isfile()方法用来判断给定的文件路径是否存在

os.remove()删除给定的文件

• if os.path.isfile(target_file_path):
•   os.remove(target_file_path)

注:在Python的os库中,remove和unlink方法实际上是等价的,它们都是用来删除一个文件。这两个方法的功能完全相同,只是命名上的不同,主要是为了兼容Unix系统的传统。

五、移动文件到新目录中

这里使用的shutil库

move方法需要两个参数,需要移动的文件路径和目标路径。使用之前需要确定文件没有被打开或被占用。

• import shutil
• shutil.move(source_file_path, target_file_path)

六、生成压缩文件

导入zipfile,os两个库

zipfile库主要用来对zip压缩文件进行操作,包括读取zip包、创建压缩文件、追加文件等。都是通过zipfile.ZipFile()方法进行,第一个参数是要操作的压缩包文件名,第二个参数是操作类型,w为创建、r为读取、a是追加。zipfile.ZIP_DEFLATED表示压缩文件使用的压缩算法是DEFLATE。

in os.walk()方法用于获取文件的三元信息,包括指定目录的目录地址、目录下的子目录列表、目录下的文件列表。

os.path.relpath()用来获取相对路径,为了使压缩包中的文件路径和实际目录路径保持一致。第一个参数是用来对比的相对目录,第二个参数默认为当前目录,如果配置则指定目录和目标目录的相对路径。

zipf.write(file_path, relative_path)用来将一个文件添加到zip包中,第一个参数是要添加的文件,第二个是添加到zip包中的位置。

• import zipfile
• import os
• def zip_directory(directory_path, zip_filename):
• # 创建一个 ZIP 文件
• with zipfile.ZipFile(zip_filename, 'w', zipfile.ZIP_DEFLATED) as zipf:
• # 遍历目录中的文件和子目录
• for root, dirs, files in os.walk(directory_path):
• for file in files:
•                 file_path = os.path.join(root, file)
• # 计算相对路径以在 ZIP 文件中保持目录结构
•                 relative_path = os.path.relpath(file_path, directory_path)
•                 zipf.write(file_path, relative_path)

七、获取脚本当前目录

os模块下的getcwd方法,用来获取脚本工作的当前文件夹路径。cwd 是 Current Working Directory 的首字母。

• import os  
• # 获取当前工作目录  
• current_directory = os.getcwd()  
• print("当前工作目录是:", current_directory)
目录
相关文章
|
2月前
|
机器学习/深度学习 Python
堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能
本文深入探讨了堆叠集成策略的原理、实现方法及Python应用。堆叠通过多层模型组合,先用不同基础模型生成预测,再用元学习器整合这些预测,提升模型性能。文章详细介绍了堆叠的实现步骤,包括数据准备、基础模型训练、新训练集构建及元学习器训练,并讨论了其优缺点。
104 3
|
3月前
|
存储 Python
Python文件操作(1)
【10月更文挑战第17天】
Python文件操作(1)
|
1月前
|
安全
Python-打印99乘法表的两种方法
本文详细介绍了两种实现99乘法表的方法:使用`while`循环和`for`循环。每种方法都包括了步骤解析、代码演示及优缺点分析。文章旨在帮助编程初学者理解和掌握循环结构的应用,内容通俗易懂,适合编程新手阅读。博主表示欢迎读者反馈,共同进步。
|
1月前
|
JSON 安全 API
Python调用API接口的方法
Python调用API接口的方法
283 5
|
2月前
|
算法 决策智能 Python
Python中解决TSP的方法
旅行商问题(TSP)是寻找最短路径,使旅行商能访问每个城市一次并返回起点的经典优化问题。本文介绍使用Python的`ortools`库解决TSP的方法,通过定义城市间的距离矩阵,调用库函数计算最优路径,并打印结果。此方法适用于小规模问题,对于大规模或特定需求,需深入了解算法原理及定制策略。
59 15
WK
|
2月前
|
Python
Python中format_map()方法
在Python中,`format_map()`方法用于使用字典格式化字符串。它接受一个字典作为参数,用字典中的键值对替换字符串中的占位符。此方法适用于从字典动态获取值的场景,尤其在处理大量替换值时更为清晰和方便。
WK
122 36
|
2月前
|
机器学习/深度学习 人工智能 算法
强化学习在游戏AI中的应用,从基本原理、优势、应用场景到具体实现方法,以及Python在其中的作用
本文探讨了强化学习在游戏AI中的应用,从基本原理、优势、应用场景到具体实现方法,以及Python在其中的作用,通过案例分析展示了其潜力,并讨论了面临的挑战及未来发展趋势。强化学习正为游戏AI带来新的可能性。
150 4
|
3月前
|
数据采集 存储 Python
Python文件操作2
【10月更文挑战第18天】
Python文件操作2
|
2月前
|
Python
Python编程中的魔法方法(Magic Methods)
【10月更文挑战第40天】在Python的世界中,魔法方法就像是隐藏在代码背后的神秘力量。它们通常以双下划线开头和结尾,比如 `__init__` 或 `__str__`。这些方法定义了对象的行为,当特定操作发生时自动调用。本文将揭开这些魔法方法的面纱,通过实际例子展示如何利用它们来增强你的类功能。
35 1
|
3月前
|
机器学习/深度学习 数据采集 数据挖掘
11种经典时间序列预测方法:理论、Python实现与应用
本文将总结11种经典的时间序列预测方法,并提供它们在Python中的实现示例。
248 2
11种经典时间序列预测方法:理论、Python实现与应用