作者 | Jeff Hale

译者 | 风车云马

责编 | Jane,Rachel

出品 | Python大本营(ID:pythonnews)

今日知识点

如何运用Python处理文件系统

前言

在编写一些Python程序的时候,我们常常需要与文件系统进行交互。在本文中,营长为大家整理了10个常用的相关命令,涉及查看信息、更改信息、删除文件等,并提供了相应的终端命令,帮助大家更高效地对文件系统及其中的文件内容进行操作。

通过一个能够实现与文件系统进行交互的Python程序,我们可以实现很多有趣的应用,但是大部分人并不知道如何实现这种交互。本文为相关研发人员和数据科学家提供了一个实现指南,并重点介绍10个基本的os和shutil命令,以便通过脚本实现Python程序与文件系统的自动交互。

文件系统和一栋房子的结构相似。在每次进行大扫除的时候,我们都需要将很多箱的文件从一个屋子移动到另一个屋子,这和使用Python移动文件的操作很像。

文件目录则像装满了东西的箱子,只不过在文件系统中,装的都是系统中存储的文件。

装在箱子中的笔记本,就像电脑中存储的文件,我们可以对其进行读/写,也可以把它们存放在目录中。

这个指南介绍了os和shutil模块中的相关方法。其中,os模块主要用于与操作系统交互,shutil模块则包含一些针对文件的操作。一般情况下,我们使用os创建目录,使用shutil移动和复制文件。

Python标准库更新:2019年2月16日新增pathlib库

在 Python 3.4 版本,标准库中增加了 pathlib 模块,以改进文件路径的处理;在3.6版本中,增加了更多pathlib与标准库的其他模块的交互,效果很好。pathlib将路径视为对象而非字符串,这使得其在解析文件路径上具有一定优势。如果你想要对pathlib有更多了解,可以阅读 Real Python 和 pbpython 提供的介绍。虽然pathlib 很方便,但它不具备我们将要探索的一些底层功能。因此,使用 os 和shutil 方法还是有必要的。

在进行更详细的介绍之前,有以下几点需要注意:

  • 本指南是基于 python3,2020年1月以后将不再支持 python 2 。

  • 在使用相关命令之前,需要在代码开头导入了 os 和 shutil 库。

  • 我的示例代码可以在GitHub上找到。

  • 请使用自己的参数替换下面引号中的参数。

下面, 本文将逐一介绍文件系统的 10 种命令方法,每个部分都会按照“方法:描述→对应的 macOS  Shell 命令”模式进行介绍,便于大家理解。

获取信息(Get Info)

  • os.getcwd():以字符串形式获取当前工作目录路径 → pwd

  • os.listdir() :以字符串列表的形式获取当前工作目录的内容→ls

  • os.walk("starting_directory_path"):返回一个生成器(generator),该生成器包含当前目录和所有子目录中的文件名称及路径信息;→没有完全等价的shell命令,不过 ls -R 命令提供了子目录名称和子目录中的文件名称

更改信息(Change Things)

  • os.chdir("/absolute/or/relative/path"):更改当前的工作路径→ cd

  • os.path.join():创建路径供后续使用→ 没有等效的命令

  • os.makedirs(“dir1 / dir2”):创建目录→ mkdir - p

  • shutil.copy2("source_file_path","destination_directory_path"):复制文件或目录→ cp

  • shutil.move("source_file_path","destination_directory_path"):移动文件或目录→ mv

  • os.remove(“my_file_path”):删除文件→ rm

  • shutil.rmtree(“my_directory_path”):删除路径及其包含的所有文件和目录→ rm –rf

以上是对十个最常用、基础的文件系统方法的初步介绍,接下来我们再深入讲解一些重要的模块和使用方法。

 

查看信息

os.getcwd()

以字符串形式返回当前工作目录

os.listdir()

以字符串列表形式返回当前目录

os.walk("my_start_directory")

创建一个生成器,用于返回关于当前目录和子目录的信息。在起始指定的目录中有效。

os.walk() 遍历包含的每个目录后,都会返回下列项:

(1)当前目录路径(字符串类型)

(2)当前目录下的子目录名称(字符串列表类型)

(3)当前目录中的文件名称(字符串列表类型的)

使用带有for循环的os.walk()来遍历目录及其子目录的内容通常很有用。例如,下面的代码将打印当前工作目录的目录和子目录中的所有文件。

import oscwd = os.getcwd()for dir_path, dir_names, file_names in os.walk(cwd):    for f in file_names:        print(f)

以上是获取信息的操作。下面让我们一起看一下更改工作目录或移动、复制、删除文件系统的命令。

更改信息

os.chdir("/absolute/or/relative/path")

此方法将当前工作路径更改为绝对路径或相对路径。

如果随后要对文件系统进行其他更改,在试用该方法时留意处理任何异常。否则,您可能正在删除不希望删除的目录或文件。

os.path.join()

os.path模块提供了许多用于路径名操作的有用方法。您可以使用它查找有关目录名称,或者目录名称的部分信息。该模块还可以用来检查文件或目录是否存在。

os.path.join()提供将多个字符串完美连接在一起的文件路径,而且是在大多数操作系统上都可以工作的路径。该模块文档的描述为,该命令可以“更加智能的连接一个或多个路径组件,返回值是路径或路径的任何成员路径的连接,每个非空路径后都有一个目录分隔符(os.sep),最后一个除外”。

另外,如果使用的是Unix或macOS系统,os.path.join()会在每个字符串之间添加一个斜杠(" / ")来创建路径。如果操作系统需要“\”,那么join会自动使用反斜杠。

os.path.join()还向其他开发人员提供了创建路径的明确信息。强烈建议读者多使用这个命令,不要每次都手动添加斜杠。

os.makedirs("dir1/dir2")

os.makedirs()能够生成目录。mkdir()方法也可以生成目录,但它不生成中间目录。所以建议使用os.makedirs()。

shutil.copy2("source_file", "destination")

在Python中复制文件和目录的方法有很多,但建议使用此命令。shutil.copy2()的优势在于,它尽可能地保留了源文件的元数据。如果你希望对文件和努力的复制有更多了解,可以阅读这篇文章。

移动文件

shutil.move("source_file", "destination")

使用shutil.move()更改文件的位置。它使用 copy2 作为后台参数默认值。

os.remove("my_file_path")

当需要删除文件时,可以使用os.remove()工具。

shutil.rmtree("my_directory_path")

shutil.rmtree()删除一个目录及其中的所有文件和目录。

删除文件

使用删除函数的时候一定要多加小心!您可以使用print()将要删除的内容打印出来,在确定不会删除错误文件后,再用相应的删除文件函数替换print()。在此向Al Sweigart致敬,感谢他在文章《Automate the Boring Stuff with Python》中进行的讨论。

最后我们再回顾一下整个方法。

10种文件系统方法概述

下面方法遵循这个模式:方法--描述--等效mac OS Shell

获取信息

  • os.getcwd() ——以字符串形式获取当前工作目录路径—— pwd

  • os.listdir() ——以字符串列表的形式获取当前工作目录的内容——ls

  • os.walk("starting_directory_path")——返回函数,其中包含当前目录和所有子目录中的目录和文件的名称和路径信息——没有完全等价的shell命令,不过ls -R提供了子目录名称和子目录中的文件名称

改动信息

  • os.chdir("/absolute/or/relative/path") ——改变当前的工作路径——cd

  • os.path.join()——创建路径供后续使用——没有等效CLI

  • os.makedirs (“dir1 / dir2”)——创建目录——mkdir - p

  • shutil.copy2("source_file_path","destination_directory_path")——复制文件或目录——cp

  • shutil.move("source_file_path","destination_directory_path")——移动文件或目录——mv

  • os.remove (“my_file_path”)——删除文件——rm

  • shutil.rmtree (“my_directory_path”)——删除路径及其包含的所有文件和目录——rm –rf

以上介绍了关于Python与文件系统交互的一些基础知识。希望大家在Ipython编辑器中多尝试这些命令,并向其他人解释这些方法,以更好的掌握和巩固知识。

如果你想对相关内容有更多了解,可以看看免费的电子书,或者多用Python编编代码。关于使用Python从文件中读写的相关操作,请查看open函数的官方文档。

原文链接:

https://towardsdatascience.com/10-python-file-system-methods-you-should-know-799f90ef13c2

留言有礼--

学习Python最大的难点是什么?留言区聊聊白,我们将在留言区随机抽取一名用户赠送Python电子书一本哦!

Python知识点回顾--

Python 只用一行代码,可以实现哪些事儿?

当pandas撞上了sql,于是一个强大的pandasql库产生了!

牛了!Python最容易入的10个坑!

球分享

球点赞

球在看

每日一课 | Python处理文件系统的10种方法相关推荐

  1. 基础必备 | Python处理文件系统的10种方法

    作者 | Jeff Hale 译者 | 风车云马:责编 | Jane,Rachel 出品 | Python大本营(ID:pythonnews) [导读]在编写一些Python程序的时候,我们常常需要与 ...

  2. python os 遍历 子目录中所有文件_Python处理文件系统的10种方法 !

    通过一个能够实现与文件系统进行交互的Python程序,我们可以实现很多有趣的应用,但是大部分人并不知道如何实现这种交互.本文为相关研发人员和数据科学家提供了一个实现指南,并重点介绍10个基本的os和s ...

  3. android 判断文件是否存在_每日一课 | Python检查文件是否存在

    在Python中,我们可以使用os.path.isfile()或pathlib.Path.is_file()(Python 3.4)来检查文件是否存在.1. pathlibPython 3.4的新功能 ...

  4. 每日一课 | Python基础

    整理 | Jane 出品 | Python大本营 初次接触 Python 到底怎么学?安装.配置完 Python 环境和工具后,很多同学都表示在一段时间内好像学习都没有成果,没有进步.其实,从基础知识 ...

  5. 每日一课 | Python数据可视化—多样化的图像

    07 大家好,我是营长,昨天营长分享了数据科学"的知识点:,不清楚的小伙伴可戳这????每日一课|Python数据可视化-如何分区和绘图 本期营长接着为大家分享Python数据可视化相关内容 ...

  6. 每日一课 | Python数据可视化—如何分区和绘图

    06 大家好,我是营长,昨天营长分享了数据科学"的知识点:,不清楚的小伙伴可戳这????每日一课|Python数据可视化-重新认识坐标系 本期营长接着为大家分享Python数据可视化相关内容 ...

  7. 每日一课 | Python综合案例实战

    使用python学习内容实现一个在线学员信息管理操作 数据临时存放在变量列表中 实现学生信息的添加,删除和查询操作. 初识界面: 添加学员信息 浏览学员信息 删除学员信息 退出操作 参考程序代码如下: ...

  8. python将列表转换为字符串_每日一课 | Python将文件读入列表

    读取日志文件的Python示例,一行一行地进入列表. # With '\n', ['1\n', '2\n', '3'] with open('/www/logs/server.log') as f: ...

  9. python 声明变量类型_每日一课 | Python 检查变量的类型

    在Python中,我们可以使用type()来检查变量的类型. num = "3.141592653589793238"print(type(num)) pi = float(num ...

最新文章

  1. GitHub上共享的简单易用 TensorFlow 代码集
  2. java线程锁的作用,大厂面经合集
  3. Docker安装mysql8
  4. REVIT使用中遇到的各种问题汇总
  5. python seed()
  6. python环境问题(pycharm)
  7. php生成图片水印,PHP生成图片加文字及图案水印办法
  8. 【BZOJ2588】Count on a tree,主席树维护链+ST表求LCA
  9. 【Python】main函数 if __name__=='__main__' 详解
  10. Oracle数据库碎片分析,oracle数据库碎片概念与分析
  11. 在window.onload中使用setTimeout
  12. pyqt5 设置窗口按钮等可用与不可用
  13. 为什么还有6亿中国人仍不放弃QQ?
  14. Linux下QtCreator不能使用搜狗输入法输入中文
  15. 还不懂这八大算法思想,刷再多题也白搭!
  16. 高德地图Amap搜索定位
  17. 在myeclipse配置的server中不能部署工程,报错如下:no projects are avaiable for deploment
  18. 从Firefox升级说学习方法
  19. 计算机锁屏打不开,电脑锁屏打不开怎么办没反应
  20. 10岁男孩玩游戏花掉1万2,和妈妈打欠条通过家务和学习成绩“还债”

热门文章

  1. Flume之生产正确的使用方式一(Singel Agent)
  2. 信息安全——安全威胁
  3. 浅述容器和容器镜像的区别
  4. mysql 经典操作_mysql常用经典操作
  5. CityMaker研修之路 02 伟景行(CityMaker)的倾斜之路
  6. oslo_messaging使用及测试
  7. BlockingQueue Interface In Java学习
  8. 人工智能数学基础之线性代数(二)
  9. http协议各个版本之解说
  10. Google 出的C++轻量级日志库_GLog_了解_使用