深度之眼(十四)——Python:文件、异常和模块

简介: 深度之眼(十四)——Python:文件、异常和模块

关于C语言的文件IO,可以看我之前写的文章,有个专栏专门讲了

系统编程 文件IO

零、导读


0a2653c851af460fa595bd959398a8f1.png


8.1 文件读写


8.1.1 文件的打开


文件的打开通用格式
 with open("文件路径","打开模式", encoding="操作文件的字符编码")as f:
        "对文件进行相应的读写操作"
使用with块的好处,执行完毕后,自动对文件进程close操作


例1:一个简单的文件读取

with open("C:/Users/DELL/Desktop/1.txt","r",encoding = "utf-8")as f: #第一步,打开文件
    text = f.read()                                                   #第二步,读取文件
    print(text)


上面是最终版


这里遇到两个问题

问题一:python报错:‘unicodeescape’ codec can’t decode bytes in position 2-3: truncated \UXXXXXXXX escape

解决:在文件夹中复制地址时,文件夹中的地址是用 \ 来分隔不同文件夹的,而Python识别地址时只能识别用 / 分隔的地址。我一开始是:C:\Users\DELL\Desktop\1.txt所以就报错了

问题二,打印出来的文字时乱码,忽然想起来我的txt是UTF-8模式,不是gbk

解决:修改encoding=UTF-8


2d65d23f6d4748949b924e4057485923.png


1. 文件路径


完整路径,如上例

程序与文件在同一文件夹,可简化成文件名

with open("1.txt","r",encoding = "utf-8")as f: #第一步,打开文件
    text = f.read()                                                  #第二步,读取文件
    print(text)


2. 打开模式


0a2653c851af460fa595bd959398a8f1.png


** 打开模式缺省,默认为只读模式**

3. 字符编码


万国码 utf-8

包含全世界所有国家需要用到的字符


中文编码 gbk

专门解决中文编码问题


windoews系统下,如果缺省,则默认为gbk(所在区域编码)


为清楚起见,除了处理二进制文件,建议不要缺省encoding


8.1.2 文件的读取


1.读取整个内容——f.read()

0a2653c851af460fa595bd959398a8f1.png

2、逐行进行读取——f.readline()


with open("C:/Users/DELL/Desktop/1.txt","r",encoding = "utf-8")as f:
    while True:
        text = f.readline()
        if not text:
            break
        else:
            print(text,end="")   #保留原文本的换行,使print()的换行不起作用

0a2653c851af460fa595bd959398a8f1.png


文档中的空行,实际上是有字符的,而文件末尾是没有的

3. 读入所有行,以每行为元素形成一个列表——f.readlines()


with open("C:/Users/DELL/Desktop/1.txt","r",encoding = "utf-8")as f:
    text = f.readlines()
    print(text)


2d65d23f6d4748949b924e4057485923.png


with open("C:/Users/DELL/Desktop/1.txt","r",encoding = "utf-8")as f:
    for text in f.readlines():
        print(text)

2e9b90b2ca334476abebe75bafe6eeaa.png


4、文本文件读取小结


文件比较大时,read(和readlines()占用内存过大, 不建议使用

readline用起来又不太方便


with open("C:/Users/DELL/Desktop/1.txt","r",encoding = "utf-8")as f:
    for text in f:
        print(text)

0a2653c851af460fa595bd959398a8f1.png


5.二进制文件


with open("C:/Users/DELL/Desktop/1.txt","rb")as f:
    print(len(f.readlines()))


8.1.3 文件的写入


1、向文件写入一个字符串或字节流(二进制)—— f.write()


with open("C:/Users/DELL/Desktop/1.txt","w",encoding = "utf-8")as f:
    f.write("姑娘你别哭泣\n")
    f.write("我俩还在一起\n")
    f.write("今天的欢乐\n")
    f.write("将是明天创痛的回忆\n")

0a2653c851af460fa595bd959398a8f1.png


如果文件存在,新写入内容会覆盖掉原内容,一定要注意! ! !


2.追加模式—— “a”


with open("C:/Users/DELL/Desktop/1.txt","a",encoding = "utf-8")as f:
    f.write("\n")
    f.write("春天刮着风\n")
    f.write("秋天下着雨\n")
    f.write("春风秋雨多少海誓山盟随风远去\n")

0a2653c851af460fa595bd959398a8f1.png

3.将一个元素为字符串的列表整体写入文件——f.writelines()


ls = ['\n','沙琪玛的美味\n', '健身精神\n', '祝福与乐观\n', '祝你有个美好的一天']
with open("C:/Users/DELL/Desktop/1.txt","a",encoding = "utf-8")as f:
    f.writelines(ls)

2d65d23f6d4748949b924e4057485923.png


8.1.4 既读又写


1.“r+”

0a2653c851af460fa595bd959398a8f1.png

2.“w+”

2d65d23f6d4748949b924e4057485923.png

3.“a+”

2e9b90b2ca334476abebe75bafe6eeaa.png


8.1.5 数据的存储与读取


通用的数据格式,可以在不同语言中加载和存储

本节简单了解两种数据存储结构csv和json


1.csv格式

由逗号将数据分开的字符序列,可以由excel打开


读取


0a2653c851af460fa595bd959398a8f1.png


写入


2d65d23f6d4748949b924e4057485923.png


2. json格式

* 写入——dump()


2e9b90b2ca334476abebe75bafe6eeaa.png


* 读取——load()

 ![在这里插入图片描述](https://ucc.alicdn.com/images/user-upload-01/ac6612c41c0f4ab4be0585e858eb3b89.png)


相关文章
|
11天前
|
机器学习/深度学习 存储 算法
解锁文件共享软件背后基于 Python 的二叉搜索树算法密码
文件共享软件在数字化时代扮演着连接全球用户、促进知识与数据交流的重要角色。二叉搜索树作为一种高效的数据结构,通过有序存储和快速检索文件,极大提升了文件共享平台的性能。它依据文件名或时间戳等关键属性排序,支持高效插入、删除和查找操作,显著优化用户体验。本文还展示了用Python实现的简单二叉搜索树代码,帮助理解其工作原理,并展望了该算法在分布式计算和机器学习领域的未来应用前景。
|
7天前
|
人工智能 Shell 开发工具
[oeasy]python065python报错怎么办_try_试着来_except_发现异常
本文介绍了Python中处理异常的基本方法,重点讲解了`try`和`except`的用法。通过一个计算苹果重量的小程序示例,展示了如何捕获用户输入错误并进行处理。主要内容包括: 1. **回顾上次内容**:简要回顾了Shell环境、Python3游乐场和Vim编辑器的使用。 2. **编写程序**:编写了一个简单的程序来计算苹果的总重量,但发现由于输入类型问题导致结果错误。 3. **调试与修正**:通过调试发现输入函数返回的是字符串类型,需要将其转换为整数类型才能正确计算。
48 32
|
4天前
|
数据库 Python
[oeasy]python066_如何捕获多个异常_try_否则_else_exception
本文介绍了Python中`try...except...else`结构的使用方法。主要内容包括: 1. **回顾上次内容**:简要复习了`try`和`except`的基本用法,强调了异常处理的重要性。 2. **详细解释**: - `try`块用于尝试执行代码,一旦发现错误会立即终止并跳转到`except`块。 - `except`块用于捕获特定类型的异常,并进行相应的处理。 - `else`块在没有异常时执行,是可选的。 3. **示例代码**:通过具体例子展示了如何捕获不同类型的异常(如`ValueError`和`ZeroDivisionError`),并解释了异常处理
35 24
|
21天前
|
监控 网络安全 开发者
Python中的Paramiko与FTP文件夹及文件检测技巧
通过使用 Paramiko 和 FTP 库,开发者可以方便地检测远程服务器上的文件和文件夹是否存在。Paramiko 提供了通过 SSH 协议进行远程文件管理的能力,而 `ftplib` 则提供了通过 FTP 协议进行文件传输和管理的功能。通过理解和应用这些工具,您可以更加高效地管理和监控远程服务器上的文件系统。
51 20
|
27天前
|
存储 数据采集 数据处理
如何在Python中高效地读写大型文件?
大家好,我是V哥。上一篇介绍了Python文件读写操作,今天聊聊如何高效处理大型文件。主要方法包括:逐行读取、分块读取、内存映射(mmap)、pandas分块处理CSV、numpy处理二进制文件、itertools迭代处理及linecache逐行读取。这些方法能有效节省内存,提升效率。关注威哥爱编程,学习更多Python技巧。
|
28天前
|
存储 JSON 对象存储
如何使用 Python 进行文件读写操作?
大家好,我是V哥。本文介绍Python中文件读写操作的方法,包括文件读取、写入、追加、二进制模式、JSON、CSV和Pandas模块的使用,以及对象序列化与反序列化。通过这些方法,你可以根据不同的文件类型和需求,灵活选择合适的方式进行操作。希望对正在学习Python的小伙伴们有所帮助。欢迎关注威哥爱编程,全栈路上我们并肩前行。
|
1月前
|
存储 算法 Serverless
剖析文件共享工具背后的Python哈希表算法奥秘
在数字化时代,文件共享工具不可或缺。哈希表算法通过将文件名或哈希值映射到存储位置,实现快速检索与高效管理。Python中的哈希表可用于创建简易文件索引,支持快速插入和查找文件路径。哈希表不仅提升了文件定位速度,还优化了存储管理和多节点数据一致性,确保文件共享工具高效运行,满足多用户并发需求,推动文件共享领域向更高效、便捷的方向发展。
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
2月前
|
计算机视觉 Python
如何使用Python将TS文件转换为MP4
本文介绍了如何使用Python和FFmpeg将TS文件转换为MP4文件。首先需要安装Python和FFmpeg,然后通过`subprocess`模块调用FFmpeg命令,实现文件格式的转换。代码示例展示了具体的操作步骤,包括检查文件存在性、构建FFmpeg命令和执行转换过程。
76 7
|
数据采集 数据挖掘 编译器
【Python 基础教程】错误与异常的处理
【Python 基础教程】错误与异常的处理
【Python 基础教程】错误与异常的处理

热门文章

最新文章

推荐镜像

更多