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

相关文章

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

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

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