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中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

mysql的基础语句和外键查询及其语句详解(推荐)

《mysql的基础语句和外键查询及其语句详解(推荐)》:本文主要介绍mysql的基础语句和外键查询及其语句详解(推荐),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋... 目录一、mysql 基础语句1. 数据库操作 创建数据库2. 表操作 创建表3. CRUD 操作二、外键

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下: