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

相关文章

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Python版本与package版本兼容性检查方法总结

《Python版本与package版本兼容性检查方法总结》:本文主要介绍Python版本与package版本兼容性检查方法的相关资料,文中提供四种检查方法,分别是pip查询、conda管理、PyP... 目录引言为什么会出现兼容性问题方法一:用 pip 官方命令查询可用版本方法二:conda 管理包环境方法

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

Python打包成exe常用的四种方法小结

《Python打包成exe常用的四种方法小结》本文主要介绍了Python打包成exe常用的四种方法,包括PyInstaller、cx_Freeze、Py2exe、Nuitka,文中通过示例代码介绍的非... 目录一.PyInstaller11.安装:2. PyInstaller常用参数下面是pyinstal