python基础-文件和异常
从文件中读取数据
比如,与执行文件在同一目录下:
with open('demo_2.txt') as file_object:
content = file_object.read()
print(content)
就可以将txt中的内容全部读取出来。
关键字with再不需要访问文件后就将其关闭。让py处理打开和关闭文件的逻辑,不要手动打开关闭,可能会产生bug。
read()在文末会返回一个空字符串,最终展示出来的就是一个空行,如果要去掉这个空字符串:
with open('demo_2.txt') as file_object:
content = file_object.read()
content = content.rstrip()
print(content)
rstrip()删除字符串末尾的空白。
如果要读取的文件不根py程序脚本在同一个目录的时候,可以使用相对路径或者绝对路径。
注意:win系统中是\,而Linux等其他系统中是/
filepath = r'D:\python-work\demo_2.txt'
with open(filepath) as file_object:
使用绝对路径,可以读取系统任何地方的文件。
注意:反斜杠\在py中被视为转义标记,为确保在win上万无一失,应以原始字符串的方式指定路径,即在字符串单引号之前加上r。
逐行读取
filepath = r'D:\python-work\demo_2.txt'
with open(filepath) as file_object:
for line in file_object:
print(line)
通过对文件对象循环,遍历文件中的每一行。但是这样遍历会发现空白行更多了。
为何会出现这些空行?因为在文件中,每行的末尾都有一个看不见的换行符,而print语句也会加上一个换行符,因此这样一来每行末尾就会有两个换行符,一个来自文件一个来自print语句。如果要清除多余的空白行,还是使用rstrip()
filepath = r'D:\python-work\demo_2.txt'
with open(filepath) as file_object:
for line in file_object:
print(line.rstrip())
这样修改之后,就只有print语句的换行符了。
文件内容转换为列表
使用with时,open返回的对象只能在with代码块中可用。如果要在with代码块之外使用,那么可以将各行存于列表中,并在with外部使用这个列表。
filepath = r'D:\python-work\demo_2.txt'
with open(filepath) as file_object:
lines = file_object.readlines()
for line in lines:
print(line.rsplit())
拼接所有行到一个字符串中:
filepath = r'D:\python-work\demo_2.txt'
with open(filepath) as file_object:
lines = file_object.readlines()
pistr = ''
for line in lines:
pistr += line.strip()
print(pistr)
strip()删除位于每行左边的空格,rstrip是删除每行右边的空格。
py读取文件内容获取的是字符串类型,如果要转换为数字则使用int(),浮点数float()
对于可处理的数据量,py没有限制,只要内存足够大。
如果要对pistr只取前面的52个字符:
print(pistr[:52] + '...')
检测某个字符是否在字符串中
search_str = 'switch1'
long_str = 'I like switch very much!'
if search_str in long_str:
print('good')
else:
print('no!')
检测到字符串后,进行替换replace
search_str = 'switch'
long_str = 'I like switch very much!'
if search_str in long_str:
print('good')
# 将switch替换为其他文字
long_str = long_str.replace('switch', '替换后的字符串')
print(long_str)
else:
print('no!')
最终输出
good
I like 替换后的字符串 very much!
向文件中添加内容
with open(file_path, "w", encoding="utf-8") as f:
f.write(‘123’)
注意:模式'w'
会创建一个新文件并写入内容,如果文件已存在,它会覆盖原有内容。
encoding="utf-8":是以utf-8编码 写入内容
如果你想在文件末尾追加内容而不是覆盖原有内容,你应该使用模式'a'
file_path = 'your_file_path.txt'
# 使用追加模式打开文件
with open(file_path, 'a', encoding='utf-8') as file:
# 写入内容到文件末尾
file.write("这是追加的内容。\n")
Python 中with open()
支持多种文件打开模式,主要分为基础模式、二进制模式和混合模式三类
一、基础模式
-
'r'
(默认):只读模式,文件必须存在,否则报错FileNotFoundError
12 -
'w'
:写入模式,文件不存在则创建,存在则清空内容12 -
'a'
:追加模式,文件不存在则创建,存在则在末尾追加内容12 -
'x'
:独占创建模式,文件存在时报错FileExistsError
,不存在则创建24
二、二进制模式(需在基础模式后加'b'
)
-
'rb'
:二进制只读,用于读取图片、视频等非文本文件12 -
'wb'
:二进制写入,会覆盖原文件12 -
'ab'
:二进制追加12
三、混合模式(支持读写,需在基础模式后加'+'
)
-
'r+'
:读写模式,文件必须存在,写入时从指针位置开始覆盖26 -
'w+'
:读写模式,文件不存在则创建,存在则清空内容46 -
'a+'
:读写追加模式,指针始终在文件末尾46 -
'rb+'
/'wb+'
/'ab+'
:二进制混合模式14
其他注意事项
- 文本模式(默认)与二进制模式的区别在于换行符处理
- 混合模式下需注意指针位置,
'a+'
写入时无法覆盖已有内容 - 推荐始终指定编码(如
encoding='utf-8'
)以避免乱码