day14文件操作

文章详细介绍了计算机数据存储的两种形式——内存和硬盘,重点讲解了数据持久化,即如何通过文件操作将数据保存至硬盘。讨论了文件路径的绝对和相对路径,文件的打开方式(如读写模式),以及文本文件的编码方式。同时,文章提供了文件读写操作的示例,并讨论了数据持久化的应用场景,如记录程序运行次数和保存用户输入数据。
摘要由CSDN通过智能技术生成

文件操作

一、数据存储

  1. 计算机数据储存

    计算机内存分为运行内容和硬盘两种:
    保存在运行内存中的数据在程序运行结束后会自动释放
    保存在硬盘中的数据会一直存在(除非手动删除或者硬盘损坏)

  2. 数据持久化 - 以文件为单位,将数据保存到硬盘中

    定义:数据持久化又叫数据本地化,指的是将程序中的数据保存在硬盘中(程序中的数据默认是保存在运行内存中的)。

    硬盘保存数据的基本单位是文件,所以如果想要把数据保存到硬盘中,就需要将数据保存到文件中。

    常见的数据持久化:数据库(将数据保存到文件中,.db、.sqlite)、Excel文件、CSV文件、TXT文件、json文件、plist文件等。

  3. 文件操作 - 操作文件内存

    文件操作基本步骤:
    第一步:打开文件

    open(文件路径,文件打开方式=‘r’,encoding=文本文件编码方式)
    1.文件路径 - 文件在计算机中的位置信息。
    文件路径分为两种,分别是绝对路径和相对路径:
    1)绝对路径:文件在计算机中的全路径
    2)相对路径:
    注意:使用相对路径之前需要先将被操作的文件放在目录中
    a.在写路径的时候,用 . 表示当前目录(当前目录指的是当前写代码的代码文件所在的文件夹)
    b.在写路径的时候,用 … 表示当前目录的上层目录

    注意:路径是以’./'开头时,可以省略

    # 使用绝对路径
    # path = r'D:/培训/第三周/2023.3.23/day14文件操作/files/test1.py'
    open( r'D:/培训/第三周/2023.3.23/day14文件操作/files/test1.py')
    
    # 使用相对路径
    open(r'./files/test1.py')
    

    2.文件打开方式 - 决定了打开文件后能做什么(是能读还是能写);还决定操作文件时,数据的类型(是字符串还是二进制)
    第一组值:r、 w、 a
    r - 只读;如果文件不存在会报错
    w - 只写;打开时会先清空原文件;如果文件不存在不会报错,会自动创建新文件
    a - 只写;(append)追加,打开时不会清空原文件;如果文件不存在不会报错,会自动创建新文件

    第二组值:t、b
    t - 字符串类型(读到的数据,和写入文件中的数据必须是字符串)
    b - 二进制类型(bytes;读到的数据,和写入文件中的数据必须是二进制)
    给打开方式赋值的时候必须在两组值中每一组选一个值,如果第二组不选默认选择t:
    rt(tr、r)、rb(br)、wt(tw、w)、wb(bw)、at(ta、a)、ab(ba)

    # -----------r是只读-----------
    # f = open('files/data1.txt','r')
    # f.read()
    
    # -------------a只写,并不会清空原文件-------------
    # f = open('files/data1.txt','a')
    # f.read() #报错!
    # f.write('abc')
    
    # -------------w只写,会清空原文件-------------
    # f = open('files/data1.txt','w')
    # f.read()
    # f.write('abc')
    
    # -------------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','wt')
    # result = f.write('hello xiaoye')
    # print(type(result))  # <class 'int'>
    # print(f.write('hello xiaoye')) # 12
    
    # 补充:常见计算机内存单位
    """
    位(bit)
    1字节(bytes) = 8位
    1kb = 1024字节
    1mb = 1024kb
    1gb = 1024mb
    1tb = 1024gb
    

    3)文本文件编码方式
    不同的文本文件编码方式,在保存同一个符号的编码值的时候采用的字节数不同
    常见的文本文件编码方式:utf-8(推荐)、gbk
    utf-8:一个数字和字母采用一个字节来保存;一个中文用3个字节
    gbk:一个数字和字母采用一个字节来保存;一个中文用2个字节

    使用编码方式的要求:前后一致(存储数据时,采用编码值必须和获取数据的时候采用编码值一致)

    # f = open('files/data2.txt','w',encoding='utf-8')
    # f.write('小爷')
    
    # f = open('files/data2.txt','r',encoding='gbk')
    # print(f.read())
    
    # f = open('files/data2.txt','w',encoding='utf-8')
    # f.write('小爷好呵呵哈哈哈')
    
    # f = open('files/data2.txt','r',encoding='utf-8')
    # print(f.read())
    

    第二步:操作文件内容(读操作、写操作)

    1.文件读操作 (获取文件内容)
    a.文件对象.read() - 获取整个文件内容(从读写位置开始获取文件结束,读写位置默认文件开头)
    b.文件对象.readline() - 从读写位置开始,读到一行结束[只针对文本文件有效];结束时读到的是一个空串

    注意:读操作会改变读写位置
    文件对象.seek(0) - 将读写位置移动到文件开头

    2.文件写操作 (包括增加内容、修改内容、删除内容)
    a.文件对象.write(内容) - 将指定内容写入到指定文件中

    # 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('----------练习:读文件内容,一行一行的读,读完为止---------------')
    # f1 = open('files/data2.txt',encoding='utf-8')
    # while True:
    #     result = f1.readline()
    #     if result == '':
    #         break
    #     print(result)
    #
    #
    # # 方法2
    # def get_file_content():
    #     f1 = open('files/data2.txt', encoding='utf-8')
    #     while True:
    #         result = f1.readline()
    #         if result == '':
    #             break
    #         yield result
    #
    # reader = get_file_content()
    # print(next(reader))
    
    
    f = open('files/data2.txt','w',encoding='utf-8')
    f.write('Python')
    f.close()
    # f.write('\njava')
    

    第三步:关闭文件

    关闭文件:文件对象.close()

二、文件应用

数据持久化方法 - 让这次运行程序产生的数据可以在下一次运行程序的时候使用

将数据持久化的步骤:

第一步:确定需要持久化的数据
第二步:创建文件,并且确定文件初始内容
第三步:做到在程序中需要这个数据的时候从文件中获取这个数据
第四步:做到这个数据如果发生改变,必须将最新的数据更新到文件中

# 案例1:写程序,打印程序运行次数
"""
第一步:运行次数
第二步:
第三步:
第四步:
"""
# # 获取上一次的运行次数
# f = open('files/RunTime.txt',encoding='utf-8')
# count = int(f.read())
# f.close()
#
# # 再让次数加1
# count += 1
#
# # 打印次数
# print(count)
#
# # 更新文件内容
# f = open('files/RunTime.txt','w',encoding='utf-8')
# f.write(str(count))


print('-----------------------------------------------')
# 需要持久化的数据:已经添加过的所有的学生的名字
# name = input('请输入需要添加的学生的名字:')
# f = open('files/student_name.txt','a',encoding='utf-8')
# f.write(name)
# f.write(' ')
# f = open('files/student_name.txt','r',encoding='utf-8')
# print(f.read())
# f.close()


# name = input('请输入需要添加的学生的名字:')
# try:
#     f = open('files/student_name.txt', encoding='utf-8')
#     all_student = f.read()
#     f.close()
# except FileNotFoundError:
#     all_student = ''
# all_student += name + ' '
# print(all_student)
# f = open('files/student_name.txt','w',encoding='utf-8')
# f.write(all_student)
# f.close()


print('---------------------------------------华丽的分割线------------------------------------')
"""
姓名: 小明
性别: 男
年龄: 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())
    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()

补充main

def download(name):
    print('-----------------------------------------------')
    print(f'{name}开始下载')
    print('检测网络状态')
    print('连接服务器')
    print('传输数据')
    print('接收数据')
    print('保存数据')
    print(f'{name}下载完成')


# 在这个if语句中的代码只会在直接执行当前模块的时候执行,在被别的模块导入的时候不会执行
if __name__ == '__main__':
    names = ['肖生克的救赎', '霸王别姬', '阿甘正传', '触不可及', '沉默的羔羊']
    for x in names:
        download(x)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值