数据持久化:
Python操作文件:
操作文本文件:
- 新建(重命名) -> 打开 -> 写数据 -> 保存关闭
- 打开 -> 读数据 -> 关闭
表格文件(excel):
- 新建 -> 打开 -> 写数据 -> 保存、关闭、重命名
- 打开 -> 读数据 -> 关闭
文件操作形式:
以什么形式操作文件:读、写:
- r:只读,文件不存在,报错
- w:只写,文件不存在先创建,如果存在,先清空
- a:追加,不存在先创建,文件存在继续添加内容
以什么数据类型操作文件:
- t: 字符串形式(如果选t可以不写,默认的,选r就相当于是 rt/tr)
- b:二进制形式:一般计算机中存储的数据都是以二进制形式存在的(图片、音频、视频等)
文件读写操作
open(参数1,参数2,参数3,参数4):
- 参数1:文件路径、文件名
- 参数2:文件操作模式
- 参数3:编码方式,encoding = ‘utf-8’
- 参数4:换行方式,newline = ‘’(读操作也可以不指定该参数)
补充:
- r 是将鼠标光标移动到下一行行首。
- 文件路径分为:相对路径、绝对路径
- 绝对路径:一个文件存放在哪个磁盘下的什么文件夹
- 相对路径:以当前文件为参照物,另一个文件相对于它的位置
- .表示当前目录
- …表示返回上级
# 以文件对象的形式打开文件
file = open(r'test.txt', 'r', encoding='utf-8', newline='')
# print(file)
# 读操作:
# read:一次性将文件中的内容以字符串的形式全部提取出来
# readline:只读取一行
# readlines:一行一行读取,将每一行放在列表中
# result = file.read()
# print(result)
result1 = file.readline()
result10 = file.readline()
result11 = file.readline()
result2 = file.readlines()
print(result1, result10, result11)
print(result2)
# 关闭文件
file.close()
写操作:
file = open('古诗.txt', 'w', encoding='utf-8', newline='')
# write:向文件写入内容
str1 = '静夜思n唐 李白n床前明月光n疑是地上霜n'
file.write(str1)
file.close()
# 追加
file = open('古诗.txt', 'a', encoding='utf-8', newline='')
# write:向文件写入内容
str1 = '举头望明月n低头思故乡'
file.write(str1)
file.close()
# 读文件
file = open('古诗.txt', 'r', encoding='utf-8')
# write:向文件写入内容
str1 = '举头望明月n低头思故乡'
print(file.read())
file.close()
# file.read() # ValueError: I/O operation on closed file.
# I/O ----> Input/Out 输入/输出
with的用法: 预定义的清理操作
- 只要退出了with的缩进,直接进行清理操作,将文件关掉。
eval的用法:
- 将字符串序列化(里面必须写长度非0的字符串):将字符串中的数据转换为它最原本的数据类型,例如: ‘[1,3,5,6]’ 转换为之后就是[1,3,5,6]
with open('eval测试.txt', 'w', encoding='utf-8', newline='') as file:
file.write('1n')
list1 = [1, 2, 3, 4, 5]
file.write(f'{list1}')
with open('eval测试.txt', 'r', encoding='utf-8') as file:
result = file.readline()
print(result, type(result))
print(file.readline())
# eval:将字符串序列化(里面必须写长度非0的字符串):将字符串中的数据转换为它最原本的数据类型,例如:
# '[1,3,5,6]' 转换为之后就是[1,3,5,6]
print(eval('1') + 2)
print('[1,2,3,45,5]'[0])
print(eval('[1,2,3,45,5]')[0])
print(eval('abcd'))
读写视频、图片: rb、rw
file = open('Y{](N))([GUFR~U[ZZ$J@8F.jpg', 'rb')
result = file.read()
file.close()
print(result)
# b'xxxxxx' 二进制字节码
# 将图片二进制数据写进去
file = open('phone2.jpg', 'wb')
file.write(result)
file.close()
with open('MarkDown为什么会这么流行.mp4', 'rb') as file:
result = file.read()
print(result)
with open('MarkDown.mp4', 'wb') as file1:
file1.write(result)
csv文件操作:
- CSV文件中的数据是以表格形式展示,但是其中的原理是文本文件的原理。
- writerow() - 单行写入,writerow中传递一个列表,列表表示一行,列表中的一个元素代表一个单元格的内容
- writerows() - 多行写入,传入一个列表,列表中有几个元素代表写几行, 其中的每个元素代表一个单元格的内容
import csv
csvfile = open('学生成绩.csv', 'w', encoding='utf-8', newline='')
# 先写列
# 使用CSV = 模块提供的writer方法进行文件写操作
myWrite = csv.writer(csvfile)
# writerow() - 单行写入,writerow中传递一个列表,
# 列表表示一行,列表中的一个元素代表一个单元格的内容
myWrite.writerow(['编号', '姓名', '年龄', '专业'])
# writerows() - 多行写入,传入一个列表,列表中有几个元素代表写几行,
# 其中的每个元素代表一个单元格的内容
myWrite.writerows([
['python001', '张三', '18', '网络工程'],
['python001', '张三', '18', '网络工程'],
['python001', '张三', '18', '网络工程']
])
csvfile.close()
# --------------------------------------------------------------------
file = open('学生成绩.csv', 'r', encoding='utf-8')
# csv.reader得到一个可迭代对象
date = csv.reader(file)
for i in date:
print(i)
file.close()
----------
file = open('学生成绩.csv', 'r', encoding='utf-8')
# csv.reader得到一个可迭代对象
date = csv.reader(file)
for i in date:
print(i)
file.close()