【Python基础篇003】3000字超详细介绍文件的最基本操作方法

简介: 【Python基础篇003】3000字超详细介绍文件的最基本操作方法

目录

🏠前言:

🚀🚀🚀打开文件最常用的三种方法:

🏠方法一:open() 方法%20%E6%96%B9%E6%B3%95)

✨✨其中对参数解释

✨✨对mode参数解释:

✨✨对编码方式的解释:

✨✨对file对象解释:

🏠方法二:with open( ) as ……%20%20as%20%E2%80%A6%E2%80%A6)

✨✨方法二介绍:

🏠方法三: try ... finally

✨✨方法三介绍:

🏠结语:


🚀🚀🚀打开文件最常用的三种方法:

🏠方法一:open() 方法

1、open() 函数常用形式是接收两个参数:文件名(file)和模式(mode)

open(file , mode = ' w')

注意:使用 open() 方法一定要保证关闭文件对象,即调用 close() 方法,目的是不让其占用内存空间节省内存

2、open()函数的完整语法格式如下:

open(file, mode = 'r', buffering = None, encoding  = None, errors = None, newline = None, closefd = True,openrwi= None)

✨✨其中对参数解释

  • file:           必需,文件路径(相对或者绝对路径)。
  • mode:      可选,文件打开模式
  • buffering: 设置缓冲
  • encoding: 一般使用utf8
  • errors:     报错级别
  • newline:  区分换行符
  • closefd:   传入的file参数类型
  • opener:   设置自定义开启器,开启器的返回值必须是一个打开的文件描述符。

✨✨对mode参数解释:

模式 描述
t 文本模式 (默认)。
x 写模式,新建一个文件,如果该文件已存在则会报错。
b 二进制模式。
+ 打开一个文件进行更新(可读可写)。
U 通用换行模式(不推荐)。
r 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。
rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。一般用于非文本文件如图片等。
r+ 打开一个文件用于读写。文件指针将会放在文件的开头。
rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。
    w 打开一个文件只用于写入。如果该文件已存在则打开文件, 并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
wb 以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。
w+ 打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。
a 打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
ab 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
a+ 打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。
ab+ 以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。
默认打开为文本模式,如果要以二进制模式打开,要加上 b 。

✨✨对编码方式的解释:

A代表一个字符

ascii:\
        A : 00000010    8位  一个字节(代表一个字符)

unicode :     

        A : 00000010 00000010 00000010 00000010     32位   四个字节

       中 :00000010 00000010 00000010 00000010     32位    四个字节

utf-8:              

        A :00000010     8位  一个字节

       中:00000010  00000010 00000010    24位   三个字节

gbk:           

        A :00000010     8位  一个字节\
       中:00000010 00000010    16位   两个字节

1、各个编码之间的二进制是不能相互识别的,会产生乱码。\
2、文件的储存,传输,不能是Unicode(只能是utf-8,utf-16,gbk,gb231等)

python3中:\
    str 在内存中使用Unicode编码。\
    bytes类型\
对于英文:\
        str :    表现形式:s = ‘zhou’\
              编码形式:010101010    unicode\
        bytes:表现形式:s = b’zhou‘\
              编码方式:000101010   utf-8,gbk…………

   对于中文 :\
        str :    表现形式:s = ‘中国’\
              编码形式:010101010    unicode\
        bytes:表现形式:s = b'\xe4\xb8\xad\xe5\x9b\xbd' (utf-8)\
              编码方式:000101010   utf-8,gbk………

✨​​​​​​​✨对file对象解释:

序号 方法及描述
常用函数
1 file.close() 关闭文件。关闭后文件不能再进行读写操作
2 file.read([size]) 从文件读取指定的字节数,如果未给定或为负则读取所有。
3 file.readline([size]) 读取整行,包括 "\n" 字符。
4  file.readlines([sizeint]) 读取所有行并返回列表,若给定sizeint>0,则是设置一次读多少字节,这是为了减轻读取压力。
5 file.seek(offset[, whence]) 设置文件当前位置(设置光标的位置方便读取)
6  file.tell() 返回文件当前位置。(或者叫做返回光标的位置)
7  file.write(str) 将字符串写入文件,返回的是写入的字符长度。
8  file.writelines(sequence) 向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。
不常用函数
9 file.fileno() 返回一个整型的文件描述符(file descriptor FD 整型), 可以用在如os模块的read方法等一些底层操作上。
10  file.flush() 刷新文件内部缓冲,直接把内部缓冲区的数据立刻写入文件, 而不是被动的等待输出缓冲区写入。
11  file.truncate([size]) 截取文件,截取的字节通过size指定,默认为当前文件位置。
12  file.isatty() 如果文件连接到一个终端设备返回 True,否则返回 False。
13 file.next() 返回文件下一行。

🏠方法二:with open( ) as ……​​​​​​​

✨​​​​​​​✨​​​​​​​方法二介绍:

用方法一每次都要调用 close() 的方法来关闭文件实在太繁琐(就是不想写😎😎)

所以Python 引入了 with 语句来自动帮我们调用 close() 方法(即会自动关闭文件)

🏠方法三: try ... finally

✨​​​​​​​✨方法三介绍:

由于文件读写时都有可能产生 IOError,一旦出错,后面的 f.close() 就不会调用。所以,为了保证无论是否出错都能正确的关闭文件,可以使用 try...finally 来实现
try: 
    f = open('/path/to/file', 'r') 
    print(f.read()) 
finally: 
    if f: 
        f.close()

相关文章
|
11天前
|
机器学习/深度学习 存储 算法
解锁文件共享软件背后基于 Python 的二叉搜索树算法密码
文件共享软件在数字化时代扮演着连接全球用户、促进知识与数据交流的重要角色。二叉搜索树作为一种高效的数据结构,通过有序存储和快速检索文件,极大提升了文件共享平台的性能。它依据文件名或时间戳等关键属性排序,支持高效插入、删除和查找操作,显著优化用户体验。本文还展示了用Python实现的简单二叉搜索树代码,帮助理解其工作原理,并展望了该算法在分布式计算和机器学习领域的未来应用前景。
|
11天前
|
JSON 数据可视化 API
Python 中调用 DeepSeek-R1 API的方法介绍,图文教程
本教程详细介绍了如何使用 Python 调用 DeepSeek 的 R1 大模型 API,适合编程新手。首先登录 DeepSeek 控制台获取 API Key,安装 Python 和 requests 库后,编写基础调用代码并运行。文末包含常见问题解答和更简单的可视化调用方法,建议收藏备用。 原文链接:[如何使用 Python 调用 DeepSeek-R1 API?](https://apifox.com/apiskills/how-to-call-the-deepseek-r1-api-using-python/)
|
21天前
|
监控 网络安全 开发者
Python中的Paramiko与FTP文件夹及文件检测技巧
通过使用 Paramiko 和 FTP 库,开发者可以方便地检测远程服务器上的文件和文件夹是否存在。Paramiko 提供了通过 SSH 协议进行远程文件管理的能力,而 `ftplib` 则提供了通过 FTP 协议进行文件传输和管理的功能。通过理解和应用这些工具,您可以更加高效地管理和监控远程服务器上的文件系统。
51 20
|
26天前
|
数据挖掘 数据处理 开发者
Python3 自定义排序详解:方法与示例
Python的排序功能强大且灵活,主要通过`sorted()`函数和列表的`sort()`方法实现。两者均支持`key`参数自定义排序规则。本文详细介绍了基础排序、按字符串长度或元组元素排序、降序排序、多条件排序及使用`lambda`表达式和`functools.cmp_to_key`进行复杂排序。通过示例展示了如何对简单数据类型、字典、类对象及复杂数据结构(如列车信息)进行排序。掌握这些技巧可以显著提升数据处理能力,为编程提供更强大的支持。
32 10
|
27天前
|
存储 数据采集 数据处理
如何在Python中高效地读写大型文件?
大家好,我是V哥。上一篇介绍了Python文件读写操作,今天聊聊如何高效处理大型文件。主要方法包括:逐行读取、分块读取、内存映射(mmap)、pandas分块处理CSV、numpy处理二进制文件、itertools迭代处理及linecache逐行读取。这些方法能有效节省内存,提升效率。关注威哥爱编程,学习更多Python技巧。
|
28天前
|
人工智能 自然语言处理 算法
随机的暴力美学蒙特卡洛方法 | python小知识
蒙特卡洛方法是一种基于随机采样的计算算法,广泛应用于物理学、金融、工程等领域。它通过重复随机采样来解决复杂问题,尤其适用于难以用解析方法求解的情况。该方法起源于二战期间的曼哈顿计划,由斯坦尼斯拉夫·乌拉姆等人提出。核心思想是通过大量随机样本来近似真实结果,如估算π值的经典示例。蒙特卡洛树搜索(MCTS)是其高级应用,常用于游戏AI和决策优化。Python中可通过简单代码实现蒙特卡洛方法,展示其在文本生成等领域的潜力。随着计算能力提升,蒙特卡洛方法的应用范围不断扩大,成为处理不确定性和复杂系统的重要工具。
69 21
|
28天前
|
存储 JSON 对象存储
如何使用 Python 进行文件读写操作?
大家好,我是V哥。本文介绍Python中文件读写操作的方法,包括文件读取、写入、追加、二进制模式、JSON、CSV和Pandas模块的使用,以及对象序列化与反序列化。通过这些方法,你可以根据不同的文件类型和需求,灵活选择合适的方式进行操作。希望对正在学习Python的小伙伴们有所帮助。欢迎关注威哥爱编程,全栈路上我们并肩前行。
|
1月前
|
存储 算法 Serverless
剖析文件共享工具背后的Python哈希表算法奥秘
在数字化时代,文件共享工具不可或缺。哈希表算法通过将文件名或哈希值映射到存储位置,实现快速检索与高效管理。Python中的哈希表可用于创建简易文件索引,支持快速插入和查找文件路径。哈希表不仅提升了文件定位速度,还优化了存储管理和多节点数据一致性,确保文件共享工具高效运行,满足多用户并发需求,推动文件共享领域向更高效、便捷的方向发展。
|
2月前
|
计算机视觉 Python
如何使用Python将TS文件转换为MP4
本文介绍了如何使用Python和FFmpeg将TS文件转换为MP4文件。首先需要安装Python和FFmpeg,然后通过`subprocess`模块调用FFmpeg命令,实现文件格式的转换。代码示例展示了具体的操作步骤,包括检查文件存在性、构建FFmpeg命令和执行转换过程。
76 7
|
2月前
|
安全
Python-打印99乘法表的两种方法
本文详细介绍了两种实现99乘法表的方法:使用`while`循环和`for`循环。每种方法都包括了步骤解析、代码演示及优缺点分析。文章旨在帮助编程初学者理解和掌握循环结构的应用,内容通俗易懂,适合编程新手阅读。博主表示欢迎读者反馈,共同进步。

热门文章

最新文章

推荐镜像

更多