python文件操作方式

一、文件操作

1.什么是文件

文件是操作系统暴露给用户能够快捷方便操作硬盘的快捷方式(接口)

2.代码如何操作文件

关键字:open()
三步走:
1.利用关键字open打开文件
2.利用其他方法操作文件
3.关闭文件

文件路径:相对路径与绝对路径

路径中出现了字母与斜杠的组合产生了特殊含义如何取消>>在路径字符串前面加一个r
r'D:\project\try.txt'

res = open('try.txt', 'r', encoding='utf8')
print(res.read())
res.close()  # 关闭文件释放资源

'''
open(文件路径,读写模式,字符编码)
    文件路径与读写模式是必须的
    字符编码是可选的(有些模式需要编码)
'''

image

# with上下文管理(能够自动帮你close())
with open(r'try.txt', 'r', encoding='utf8') as f:  # f=open()  f.close()
    print(f.read())

'''代码操作文件,一般使用with语法'''

3.文件读写模式

r, 只读模式(只能看不能改)

# 路径不存在,直接报错
with open(r'a.txt', 'r', encoding='utf8') as f1:
    f1.read()
# 路径存在
with open(r'try.txt', 'r', encoding='utf8') as f2:
    print(f2.read())  # 读取文件所有内容

w, 只写模式(只能写不能看)

# 路径不存在,自动创建
with open(r'b.txt', 'w', encoding='utf8') as f1:
    f1.write('新建一个文件')

# 路径存在,1.先清空文件内容  2.在执行写入操作
with open(r'try.txt', 'w', encoding='utf8') as f2:
    f2.write('insist insist')

image

a, 只追加模式(追加内容)

# 路径不存在, 创建一个新的文件,可以写入内容但不可以读
with open(r'money.txt', 'a', encoding='utf8') as f1:
    # f1.read()  # 报错
    f1.write('insist study')

# 路径存在, 在文件内容的尾部追加新的写入内容
with open(r'money.txt', 'a', encoding='utf8') as f2:
    f2.write('graduation from Oldboy')

目前所说的r w a读写模式还只能操作文本文件
操作视频图片等其他文件得使用下方提到的二进制模式操作
image
image

二、文件操作方法

1.读系列

# 1. 读系列
with open(r'11.py', 'r', encoding='utf8') as f:
    print(f.read())  # 一次性读取文件内所有内容
    print(f.readline())  # 每次只读文件一行内容
    print(f.readlines())  # 读取文件所有内容,组织成列表,每个元素是文件的每行内容
    print(f.readable())  # 判断当前文件是否具备读的能力

image

2.写系列

with open(r'try.txt', 'w', encoding='utf8') as f:
    f.write('insist every day')  # 往文件内写入内容
    f.writelines(['elijah\n', 'jason\n', 'egon\n'])  # 将列表中的多个字符串元素全部写入
    f.write(123)  # 写入操作的时候只能写入字符串,写入数字会报错
    print(f.writable())  # 判断该文件是否具备写的能力
    f.flush()  # 直接将内存中的数据刷到硬盘中,相当于ctrl + s

3.文件优化操作

# with open(r'11.py', 'r', encoding='utf8') as f:
#     # print(f.read())
#     for line in f:  # 文件变量名f支持for循环 相当于一行行读取文件内容
#         print(line)
'''以后涉及多行文件内容情况一般都是采用for循环读取'''
'''
1.一次性读完之后光标停留在文末尾 无法再次读取内容
2。该方法在读取大文件的时候 可能会导致内存溢出的情况
    解决上述问题的策略就是逐行读取文件内容
'''

4.练习多用户注册&登录功能

import os


while True:
    # 打印功能列表
    print(
        '''
               1.退出
               2.注册
               3.登录
        '''
    )

    choice = input('请输入业务编号:')
    if choice == '0':
        break
    elif choice == '1':
        # 注册功能
        print('用户注册...')
        # 获取用户名和密码
        username = input('请输入用户名:').strip()
        password = input('请输入密码:').strip()
        # 把用户数据组合成字符串
        user_data = f'{username}|{password}'
        # 判断用户数据文件是否已经存在,如果存在,提醒用户
        if os.path.exists(rf'D:\pythonProject1(1102)\db\{username}.txt'):
            print(f'用户 【{username}】 已存在,请不要重复注册')
        else:
            # 在数据库中文件创建相应的用户文件,存入用户信息
            with open(rf'D:\pythonProject1(1102)\db\{username}.txt', 'w', encoding='utf8') as f:
                f.write(user_data)
                print(f'用户 【{username}】 创建成功!')
    elif choice == '2':
        # 登录功能
        print('用户登录...')
        # 获取用户名和密码
        username = input('请输入用户名:').strip()
        password = input('请输入密码:').strip()
        # 判断用户数据文件路径是否存在
        if os.path.exists(rf'D:\pythonProject1(1102)\db\{username}.txt'):
            # 如果存在,读取文件数据并作解压赋值,取出用户名和密码
            with open(rf'D:\pythonProject1(1102)\db\{username}.txt', 'r', encoding='utf8') as f:
                res = f.read()
                name, pwd = res.split('|')
                if username == name and password == pwd:
                    print('登录成功')
                else:
                    print('用户名或密码错误')
        else:
            print('用户不存在...')
    else:
        print('请输入正确的编号...')

image

三、文件操作模式

t >> 文本模式

1.默认的模式。。r w a >>> rt、 wt、 at
2.该模式所有操作都是以字符串为基本单位(文本)
3.该模式必须要指定encoding参数
4.该模式只能操作文本文件

b >> 二进制模式

1.该模式可以操作任意类型的文件
2.该模式所有操作都是以bytes类型(二进制)为基本单位
3.该模式不需要指定encoding参数
rb、wb、ab

文件拷贝练习

while True:
    # 获取要拷贝的文件路径和目标粘贴位置路径
    file_path = input('请输入要拷贝的文件路径(0为退出):')
    if file_path == '0':
        break
    copy_path = input('请输入要粘贴的目的地位置:')

    # 以二进制模式打开并读取文件数据
    with open(file_path, 'rb') as f:
        res = f.read()

    # 以二进制模式写入新的文件路径
    with open(copy_path, 'wb') as f1:
        for line in res:
            f1.write(res)
        print('拷贝成功')

# 方式2
# 1.待拷贝的文件路径
wait_copy_file = input('file path>>>:').strip()
# 2.新的文件路径
new_file_path = input('new path>>>:').strip()
# 3.以r模式打开步骤1的路径 以w模式打开步骤2的路径
with open(r'%s' % wait_copy_file, 'rb') as f1, \
        open(r'%s' % new_file_path, 'wb') as f2:
    for line in f1:
        f2.write(line)

image

image

二进制的读写操作

# t   文本模式
# 
# a.txt 文件内容
# insist
# 坚持吧坚持吧
# 顶住顶住

with open(r'a.txt', 'rb') as f:
    print(f.read().decode('utf8'))
    print(f.read(6).decode('utf8'))  # insist

with open(r'a.txt', 'r', encoding='utf8') as f1:
    # print(f1.read())
    print(f1.read(8))  # insist  坚

'''
read() 括号内可以放数字
    在t模式下数字表示字符个数
    在b模式下数字表示字节格式
英文字符统一使用一个bytes来表示
中文字符统一使用三个bytes来表示
'''

文件内光标的移动

# 文件内光标的移动
with open(r'a.txt', 'rb') as f:
    print(f.read(6))  # b'insist'
    print(f.tell())  # 查看光标移动了多少个字节  6
    f.seek(8, 0)
    print(f.tell())  # 8
    print(f.read().decode('utf8'))

'''
控制文件内光标的移动  f.seek()
f.seek(offset, whence)
    offset表示位移量
        始终是以字节为最小单位
            正数从左到右移动
            负数从左往右移动
    whence表示模式
        0: 以文件开头为参考系(支持tb两种模式)
        1: 只支持b模式 以当前位置为参考系
        2: 只支持b模式 以文件末尾为参考系
'''

文件的内容修改

# 文件内容修改
# 方式1 覆盖
with open(r'a.txt', 'r', encoding='utf8') as f:
    data = f.read()

with open(r'a.txt', 'w', encoding='utf8') as f1:
    new_data = data.replace('insist', 'hard study')
    f1.write(new_data)

# 方式2 新建
import os

with open('a.txt', 'r', encoding='utf8') as f, \
        open('a.txt.swap', 'w', encoding='utf8') as f1:  # 同时打开两个文件的方式
    for line in f:
        f1.write(line.replace('坚持', '努力'))  # 替换掉原文件的字符
os.remove('a.txt')
os.rename('a.txt.swap', 'a.txt')
posted @ 2021-11-10 16:40  elijah_li  阅读(228)  评论(2编辑  收藏  举报
//一下两个链接最好自己保存下来,再上传到自己的博客园的“文件”选项中