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 panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON:

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统