- 1、open()函数与文件打开模式
- 2、file对象提供的函数
- 3、常见的文件操作示例
- 4、os模块里的常用函数
Python中读写文件非常简单,通过 open()函数
可以打开文件并返回文件对象。我们可以使用help函数来查看open函数具体的参数:
一般了解前两个参数就够了,file参数代表文件名,如果不带上路径的话,会在当前文件夹里查找, 而mode参数代表文件的打开模式,有如下表所示的几种打开模式:
写模式打开,若文件存在,先删除,然后重新创建 |
追加模式打开,追加到文件末尾,seek()指向其他地方也没用,文件不存在,自动创建 |
可读写模式,可配合其他模式使用,比如r+,w+ |
如果文件已存在,用此模式打开会引发异常 |
另外,实用open函数打开文件时要做下:异常捕获,比如下面这样的代码:
如果test.txt文件不存在的话,会抛出一个FileNotFoundError错误
,所以需要进行异常捕获。另外,文件使用完毕后必须关闭,文件对象会占用操作系统的资源,操作系统同一时间能打开的文件数量也是有限的。所以为了保证正常或发生异常的时候文件都能关闭,需要把关闭操作写到finally块里,示例代码如下:
但是每次都要这样写的话显得有些繁琐了,可以使用Python提供的with语句
来简化这个操作。
相比每次都要写try-finally异常捕获,这种方式简洁得多,而且不用怕忘记关闭文件。
file对象提供了如下表所示的可供调用的方法:
关闭文件,关闭后文件不能再进行读写操作 |
从文件读取指定的字节数,如果未设置或为负数,读取所有 |
读取整行,包括换行符’\n’ |
设置当前文件指针的位置,从from(0文件起始位置,1当前位置, 2文件末尾)偏移offset个字节 |
写入一个序列字符串列表,如果要换行,需要自己加入每行的换行符 |
截断文件并返回截断的字节长度,指定长度就从开头开始截断指定长度, 其余内容删除;不指定的话,从开头截取到当前位置,其余内容删除。 |
文件的常用操作有创建,写入,读取,还有追加,代码示例如下:
创建了一个可读写的文件:test.txt
内容写入成功!
输出文件内容:人生苦短我用Python!
内容追加成功!
输出文件内容:人生苦短我用Python!
Hello Python!
复制代码
4、os模块里的常用函数
Python中为我们提供了一个
os模块
用于处理文件和目录
,除此之外它的子模块path模块
还提供了文件路径相关
的一些函数,通过这些函数可以完成文件或者文件夹的批处理操作,比如文件批量改名,内容替换等。
os模块常用的函数如下表所示:
关闭文件,关闭后文件不能再进行读写操作 |
不写参数默认列举当前目录下所有文件和文件夹,’.’当前目录, |
调用系统提供的小工具,比如计算器 |
遍历top参数指定路径下所有子目录,返回一个三元组(路径, [包含目录],[包含文件]) |
路径分隔符,Win下是’\’,Linux下是’/’ |
当前平台使用的行终止符,win下是’\r\n’,Linux下是’\n’ |
输出用于分割文件路径的字符串 |
执行shell命令,直接显示 |
os.path模块常用的函数如下表所示:
将路径名与文件名拼接成一个完整路径 |
分割路径与文件名,返回元组(f_path, f_name),如果完全使用目录,它也会将最后一个目录作为文件名分离,且不会判断文件或目录 |
获得文件大小,单位是字节 |
获得文件最近访问时间,返回的是浮点型秒数 |
获得文件的创建时间,返回的是浮点型秒数 |
获得文件的修改时间,返回的是浮点型秒数 |
判断路径(文件或目录)是否存在 |
判断是否存在且是一个目录 |
判断是否存在且是一个文件 |
判断是否存在且是一个符号链接 |
判断是否存在且是一个挂载点 |
判断两个路径是否指向同一个文件 |
比如说现在有这样一批文件,文件内容都是:
1.Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++
里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。
Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员
以优雅的思维方式进行复杂的编程。
现在需要把文件里的Java都替换成Python,我们可以通过编写脚本来完成这项繁琐的工作,具体代码如下:
1.Python是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Python语言具有功能强大和简单易用两个特征。Python语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程。
复制代码
有时我们需要对一堆文件进行批量命名,比如需要把下面这样的图片名字统一改成image_1这样的形式。在学习本节之前,你可能需要复制下image_,然后一个个图片重命名,学习完本节后我们可以动手写一个批量文件重命名的脚本。
程序还是比较简单的,分两步:
1s不到改完108个图片,简直不要太爽,真人生苦短,我用Python!
如果本文对你有所帮助,欢迎
Python3 中有六个标准的数据类型:
Python3 的六个标准数据类型中:
1)引用计数机制:Python内部使用引用计数,来保持追踪内存中的对象。
2)垃圾回收机制:当一个对象的引用计数归零时,它将被垃圾收集机制处理掉;
循环垃圾回收器,确保释放循环引用对象。
Python提供了对内存的垃圾收集机制,但是它将不用的内存放到内存池而不是返回给操作系统:
Pymalloc机制:为了加速Python的执行效率,Python引入了一个内存池机制,用于管理对小块内存的申请和释放。
对于Python对象,如整数,浮点数和List,都有其独立的私有内存池,对象间不共享他们的内存池。也就是说如果你分配又释了大量的整数,用于缓存这些整数的内存就不能再分配给浮点数。
Python 的内存管理是由私有heap 空间管理的。所有的Python 对象和数据结构都在一个私有heap 中。程序员没有访问该heap 的权限,只有解释器才能对它进行操作。
为Python 的heap 空间分配内存是由Python 的内存管理模块进行的,其核心API 会提供一些访问该模块的方法供程序员使用。
Python 有自带的垃圾回收系统,它回收并释放没有被使用的内存,让它们能够被其他程序使用。
Python装饰器是一个函数,是Python中的特有变动,可以使修改函数变得更容易。它可以使函数在不修改本身的函数定义外,动态产生额外的功能。
装饰器的功能是将被装饰的函数当作参数传递给与装饰器对应的函数(名称相同的函数),并返回包装后的被装饰的函数
数组和元组之间的区别:数组内容是可以被修改的,而元组内容是只读的。另外,元组可以被哈希,比如作为字典的关键字。
pass是一个占位符,用来表示空白,不被执行。
在大数据技术流行的今天,SQLFlow 可以通过分析各种数据库对象的定义给开发和管理者带来很大的助力.能够让您在大数据时代应对自如,如虎添翼. 在之前的文章中我们已经详细介绍过SQLFlow是什么.能 ...
在上spark的时候,一开始需要虚拟机模拟真实环境,而spark主要的三种模式:local.standalone.yarn 均可以通过虚拟机模拟. 这里要讨论的是业务逻辑如何和 spark 结合,具体 ...
SOLID是面向对象的软件开发中的5条准则,也是开发人员可以提升自己代码质量的准则.那么如何衡量自己的代码是否符合SOLID准则呢?NDepend这款工具也许可以帮得上忙.本文将介绍一些NDepend ...