python爬虫基础------文件的相关操作(第十天)

2024-04-01 02:52

本文主要是介绍python爬虫基础------文件的相关操作(第十天),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🎈🎈作者主页: 喔的嘛呀🎈🎈
🎈🎈所属专栏:python爬虫学习🎈🎈
✨✨谢谢大家捧场,祝屏幕前的小伙伴们每天都有好运相伴左右,一定要天天开心哦!✨✨ 

  

小伙伴们,今天我们学习的内容是文件的相关操作

python文件的相关操作

目录

python文件的相关操作

一、文件的打开与关闭

文件路径

访问模式

关闭文件

自动关闭文件(推荐)

二、文件的读写

写数据(write)

读取数据(read)

读取一行数据(readline)

读取多行数据(readlines)

三、序列化和反序列化

序列化

反序列化

四、文件异常处理

try...except...finally 语句

with 语句(自动关闭文件)


一、文件的打开与关闭

打开文件/创建文件 在python,使用open函数,可以打开一个已经存在的文件,或者创建一个新文件 open(文件路径,访问模式) 示例如下:

file = open('filename.txt', 'r')  # 打开文件用于读取
file = open('filename.txt', 'w')  # 打开文件用于写入,会覆盖文件中已有的内容
file = open('filename.txt', 'a')  # 打开文件用于追加,新写入的内容会被添加到文件末尾
file = open('filename.txt', 'r+') # 打开文件用于读写

第一个参数是文件名,第二个参数是打开文件的模式(读取、写入、追加等)。

文件路径

  (1)绝对路径:指的是绝对位置,完整地描述了目标的所在地,所有目录层级关系是一目了然的。

例如: E:\python ,从电脑的盘符开始,表示的就是一个绝对路径。 (2)相对路径:是从当前文件所在的文件夹开始的路径。 test.txt ,是在当前文件夹查找 test.txt 文件 ./test.txt ,也是在当前文件夹里查找 test.txt 文件, ./ 表示的是当前文件夹。 ../test.txt ,从当前文件夹的上一级文件夹里查找 test.txt 文件。 ../ 表示的是上一级文件夹 demo/test.txt ,在当前文件夹里查找 demo 这个文件夹,并在这个文件夹里查找 test.txt 文件。

访问模式

| 访问

模式说明
r以只读方式打开文件。文件的指针将会放在文件的开头。如果文件不存在,则报错。这是默认模式。
w打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将
会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
r+打开一个文件用于读写。文件指针将会放在文件的开头。
w+打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。
a+打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模
式。如果该文件不存在,创建新文件用于读写。
rb以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。
wb以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新
文件。
ab以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是
说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。
rb+以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。
wb+以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文
件。
ab+以二进制格式打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。如果该文
件不存在,创建新文件用于读写。

关闭文件

使用完文件后,应该及时关闭文件以释放资源。可以使用文件对象的 close() 方法关闭文件:

file.close()

自动关闭文件(推荐)

为了确保文件被正确关闭,通常使用 with 语句来打开文件,这样文件在退出 with 代码块时会自动关闭:

with open('file.txt', 'r') as file:# 在这里进行文件操作
# 文件已经自动关闭,无需手动调用 file.close()

使用 with 语句可以确保文件被正确关闭,即使在处理文件过程中发生异常也会被正确处理。

二、文件的读写

写数据(write)

使用 write() 可以向文件写入数据。示例中展示了如何向文件中写入内容。如果文件不存在,则创建文件;如果文件已存在,则清空文件内容后写入数据。

# 新建一个文件,文件名为:test.txt
f = open('test.txt', 'w')
# 关闭这个文件
f.close()
f = open('test.txt', 'w')
f.write('hello world, i am here!\\n' * 5)
f.close()

读取数据(read)

使用 read(num) 可以从文件中读取数据,num 表示要读取的数据的长度(单位是字节)。如果不指定 num,则表示读取文件中所有的数据。

f = open('test.txt', 'r')
content = f.read(5)  # 最多读取5个字符
print(content)
print("-" * 30)  # 分割线,用来测试
content = f.read()  # 从上次读取的位置继续读取剩下的所有的数据
print(content)
f.close()  # 关闭文件

读取一行数据(readline)

readline() 用来读取一行数据。

f = open('test.txt', 'r')
content = f.readline()
print("1:%s" % content)
content = f.readline()
print("2:%s" % content)
f.close()

读取多行数据(readlines)

readlines() 可以按行读取整个文件的内容,并返回一个列表,其中每一行是列表的一个元素。

f = open('test.txt', 'r')
content = f.readlines()
print(type(content))
for temp in content:print(temp)

三、序列化和反序列化

序列化是将对象转换为字节序列的过程,而反序列化则是将字节序列转换回对象的过程。Python 中可以使用 JSON 模块进行序列化和反序列化操作。

序列化

使用 json.dumps() 方法将对象转换为 JSON 格式的字符串,或使用 json.dump() 方法将对象写入文件中。

import json# 将列表转换为 JSON 字符串
names = ['zhangsan', 'lisi', 'wangwu']
json_str = json.dumps(names)
print(json_str)# 将 JSON 字符串写入文件
with open('names.json', 'w') as file:json.dump(names, file)

反序列化

使用 json.loads() 方法将 JSON 格式的字符串转换为对象,或使用 json.load() 方法从文件中加载 JSON 数据并转换为对象。

import json# 将 JSON 字符串转换为列表
json_str = '["zhangsan", "lisi", "wangwu"]'
names = json.loads(json_str)
print(names)# 从文件中加载 JSON 数据并转换为对象
with open('names.json', 'r') as file:names = json.load(file)print(names)

JSON 格式非常适合在不同语言之间进行数据交换,因为它是一种通用的格式,并且易于阅读和解析。

四、文件异常处理

在文件操作过程中,可能会发生各种异常,如文件不存在、文件权限错误等。为了保证程序的健壮性,需要使用异常处理机制来捕获和处理这些异常。

try...except...finally 语句

try:file = open('file.txt', 'r')# 文件操作
except FileNotFoundError as e:print("文件不存在:", e)
except IOError as e:print("IO错误:", e)
finally:if file:file.close()

with 语句(自动关闭文件)

使用 with 语句打开文件,可以在退出 with 代码块时自动关闭文件,不需要手动调用 close() 方法。

with open('file.txt', 'r') as file:# 文件操作

完整示例

try:with open('file.txt', 'r') as file:content = file.read()print(content)
except FileNotFoundError as e:print("文件不存在:", e)
except IOError as e:print("IO错误:", e)

以上是关于文件对象的属性和方法,以及异常处理的详细介绍。这些知识对于进行文件操作和处理文件操作中的异常非常重要。

好了小伙伴们,今天的学习就到这里了,再见喽!

这篇关于python爬虫基础------文件的相关操作(第十天)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/866042

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四