day14 文件操作
01 数据存储
1.计算机数据存储
计算机内存运行分为运行内存和硬盘两种;保存在运行内存中的数据在程序结束运行后会释放,保存在硬盘中的数据会一直存在(除非手动删除或者硬盘损坏)
2.数据持久化 - 以文件为单位,将数据保存到硬盘中
数据持久化又叫数据本地化,指的是将程序中的数据保存在硬盘中(程序中的数据默认是保存在运行内存中)
硬盘保存数据的基本单位是文件,所以如果想要把数据保存到硬盘中就需要把数据保存到文件中。
常见是数据持久化:数据库(.db、.sqlite)、excel文件、csv文件、txt文件、plist文件等。
3.文件操作 - 操作文件内容
文件操作基本操作:打开文件 ->操作文件内容(读操作、写操作) -> 关闭文件
1)打开文件
open(文件路径,文件打开方式,encoding=文本文件编码方式)
1.文件路径 - 文件在计算机中的位置信息。
文件路径分为两种,分别是绝对路径和相对路径:
1)绝对路径:文件在计算机中的全路径
2)相对路径:
注意:使用相对路径之前需要先将被操作的文件放在目录中
a.在写路径的时候用 . 表示当前目录(当前目录指的是当前写代码的代码文件所在的代码文件夹中)
b.在写路径的时候用 .. 表示当前目录的上层目录
注意:路径是以'./'开头的时候,'./'可以省略
#使用绝对路径
open(r'E:\python\01基础课\day14 文件操作\files\data1.txt')
#使用相对路径
open(r'files/data1.txt')
open(r'.\files/data1.txt')
open(r'..\day14 文件操作\code\demo.py')
2)文件打开方式 - 决定了打开文件后能做什么(是能读还是能写?);还决定操作文件的时候数据的类型(是字符串还是二进制)
第一组值:r、w、a
r - 只读 如果文件不存在会报错
w - 只写:打开时会先清空原文件
a - 只写:打开的时候不会清空原文件
#w、a打开不存在的文件不会报错并且会自动创建文件
第二组值:t、b
t - 字符串类型(读到的数据,和写入文件中的数据必须是字符串)
b - 二进制类型(bytes;读到的数据,和写入文件中的数据必须是二进制)
给打开方式赋值的时候必须在两组值中每一组选一个值,如果第二组不选默认选择 t:
rt(tr,r)、rb(br)、wt(bw)、wb(bw)、at(ta、a)、ab(ba)
# f=open('files/data1.txt','r')
# f.read()
# f.write('abc') # not writable
# ----a是只写,并且不会清空原文件---
# f = open('files/data1.txt', 'a')
# # f.read() # 报错!
# f.write('abc')
# ---w是只写,并且会清空源文件
# f = open('files/data1.txt', 'w')
# f.write('abc')
# f.read() # 报错!
# ----r打开不存在的文件程序报错-----
# f = open('files/data2.txt', 'r')
# ----w 和 a 打开不存在的文件的时候不会报错,并且会自动创建这个文件
# f = open('files/data2.txt', 'w')
# f = open('files/data3.txt', 'a')
# --------------- t - 数据的类型是字符串 ---------------
# f = open('files/data1.txt', 'rt')
# result = f.read()
# print(type(result)) # <class 'str'>
# f = open('files/data1.txt', 'at')
# f.write('abc')
@@@ 补充:常见计算机内存单位
位(bit)
1字节(bytes) = 8位
1kb = 1024字节
1mb = 1024kb
1G = 1024mb
1T = 1024G
3)文本文件编码方式
不同的文本文件编码方式,在保存同一个符号的编码值的时候采用的字节数不同
常见的文本文件编码方式:uf-8、gbk
utf-8:一个数字和字母采用一个字节保存;一个中文用三个字节
gkb:一个数字和字母采用一个字节保存;一个中文用两个字节
使用编码方式的要求:前后一致(存储数据的时候采用编码值必须和获取数据的时候采用编码值一致)
# 以b的方式打开文件,encoding不能赋值
# f=open('files/data4.txt','w',encoding='utf-8')
# f.write('hello!世界!')
# f=open('files/data4.txt','r',encoding='utf-8')
# print(f.read())
4)操作文件
1.文件读操作 (获取文件内容)
a.文件对象.read() - 获取整个文件内容(从读写位置开始获取文件结果,读写位置默认文件开头)
b.文件对象.readline() - 从读写位置开始读到一行结束(只针对文本文件有效)
c.文件对象.readlines()
注意:读操作会改变读写位置
文件对象.seek(0) - 将读写位置移动到文件开头
2.文件写操作 (包括增、修改、删)
a.文件对象.witer(内容) - 将指定内容写入文件中
3.关闭文件
文件对象.close()
为了避免忘记关闭文件:
with open(文件路径,打开方式,编码方式) as 文件对象:
代码块
f=open('files/data1.txt',encoding='utf-8')
# result=f.read()
# print(result)
# print('----------------------------分隔符------------------------------------')
# f.seek(0)
# result=f.read()
# print(result)
#
# print('----------------------------分隔符------------------------------------')
# f.seek(0)
# print(f.readline())
# print('----------------------------分隔符-------------------------------------')
# print(f.readline())
# print('----------------------------分隔符-------------------------------------')
# print(f.readline())
# print('----------------------------分隔符-------------------------------------')
# print(f.readline())
# print('----------------------------分隔符-------------------------------------')
# result=f.readline()
# print(type(result),len(result))
# 练习:一行一行读,读完为止
# def get_files_readline():
# f=open('files/data1.txt',encoding='utf-8')
# while True:
# result=f.readline()
# if len(result)==0:
# break
# yield result
#
# reader=get_files_readline()
# print(next(reader))
f=open('files/data2.txt','w',encoding='utf-8')
f.write('Python')
f.write('\nJava')
f.close()
# f.write('sd') # I/O operation on closed file.
02 数据持续化的应用
1.数据持久化方法 - 让这次运行程序产生的数据可以在下一次程序运行的时候使用
import tarfile
第一步:确定需要持久化的数据
第二步:创建文件,并且确定文件初始内容
第三步:做到在程序中需要这个数据的时候从文件中获取数据
第四步:做到这个数据如果发生改变,必须将最新的数据更新到文件中
# 案例1:写程序打印程序运行次数
# 获取上一次的运行次数
# f=open(r'files/runtime.txt',encoding='utf-8')
# count=int(f.read())
# f.close()
# # 再让次数+1
# count+=1
# # 打印次数
# print(count)
#
# # 更新文件内容
# f=open(r'files/runtime.txt','w',encoding='utf-8')
# f.write(str(count))
#练习1:
'''
请输入需要添加的学生名字:小明
小明
请输入需要添加的学生名字:小花
小明 小花
'''
# 需要持久化的数据是学生名字
# name=input('请输入需要添加的学生名字:')
# f=open('files/student_names.txt',encoding='utf-8')
# all_student=f.read()
# f.close()
# all_student+=' '+name
# print(all_student)
# f=open('files/student_names.txt','w',encoding='utf-8')
# f.write(all_student)
# f.close()
'''
姓名:小明
性别:男
年龄:18
打印:【{'name':'小明','gender':'男','age':18}]
姓名:小花
性别:女
年龄:20
打印:【{'name':'小明','gender':'男','age':18},{'name':'小花','gender':'女','age':20}]
'''
#需要持久化的数据是学生信息
name=input('姓名:')
gender=input('性别:')
age=int(input('年龄:'))
try:
f=open('files/学生信息.txt',encoding='utf-8')
all_student=eval(f.read()) #用了eval需要在指定文件中加一个空列表,不然会报错 utf-8'读取出来的是字符串,要将其变为列表的形式
f.close()
except FileNotFoundError:
all_student=[]
all_student.append({'name':name,'gender':gender,'age':age})
print(all_student)
f=open('files/学生信息.txt','w',encoding='utf-8')
f.write(str(all_student))
f.close()