文件的基本操作
1. 我们能够操作哪些类型的文件:
.txt 没有后缀名的文件
# 我们现在不能操作word、Excel、PPT等文件暂时不能够操作
numpy、pandas等模块可以操作
2. 如何操作文件
"""
三步法:
1. 打开文件(open)
2. 读或者写
3. 关闭文件
"""
# open('要操作的文件路径', '读写模式', '字符编码')
文件的路径:
相对路径
绝对路径
'D:\Python27\day10\a.txt'
# 当路径中出现了字母和斜杠的组合会产生一些特殊的含义,所以我们应该给去掉:
# 2. 读取文件
# helloworld
print(f.read()) # 类似于是文件的内置方法
# 3. 关闭文件
f.close()
'''第二种方式来操作文件'''
# with上下文管理器打开文件!
# as:起别名
# 它的特点就在于:能够自动关闭文件
with open('a.txt', 'r', encoding='utf-8') as f: # f=open('a.txt', 'r', encoding='utf-8') f.close()
print(f.read())
文件的读写模式
"""
语法格式:
open(文件路径,读写模式,字符编码)
文件路径:是必须写的
读写模式:也是必须写的
字符编码:可选的
"""
读写模式:
r(只读:只能读不能写) w(只写:只能写,不能读) a(append:在原来的基础之上在添加新的内容)
1. 只读模式
# 1. 读模式
"""当文件路径不存在的时候,会直接保存"""
# f = open('b.txt', 'r', encoding='utf-8') # No such file or directory: 'b.txt'
# f = open('a.txt', 'r', encoding='utf-8') # No such file or directory: 'b.txt'
# print(f.read())
# f.close()
#
# with open('a.txt', 'r', encoding='utf-8') as f:
# print(f.read())
# 2. 写模式
"""写模式的特征:
1. 当文件路径不存在的时候, 会新建出来一个文件,而不报错
2. 写模式会把原来的数据覆盖掉,从新写入新的数据(重要)
"""
# with open('b.txt', 'w', encoding='utf-8') as f:
# # pass # 为了不全语法结构
# # f.write('hello')
# # f.write('hahahahhah')
# f.write('jerry')
# 3. 追加模式
"""追加模式:当路径不存在的时候,也会新建出来文件
记住:它是追加写,而不是覆盖原来的内容!
"""
with open('c.txt', 'a', encoding='utf-8') as f:
f.write('hello world')
f.write('hello world1')
f.write('hello world2')
f.write('hello world3')
f.write('hello world4')
f.write('hello world5')
读写操作相关的方法
1. 读系列
# 读系列
with open('a.txt', 'r', encoding='utf-8') as f:
# print(f.read()) # read方法是一次性读取文件中得所有数据
# print(f.readline()) # helloworld1
# print(f.readline()) # readline一次只读文件的一行内容
# print(f.readlines()) # 一次性读取文件的所有内容,然后每一个内容作为列表的一个元素返回,返回的数据类型是:列表
print(f.readable()) # able ation un multi ...
2. 写系列
# 写系列
### 做后端程序员:最重要的是安全意识
with open('a.txt', 'w', encoding='utf-8') as f:
# f.write('jerry say hello ')
# f.writelines(['hello\n', 'jerry\n', 'kevin\n', 'jason\n'])
print(f.writable())
print(f.readable())
文件的读操作优化
with open('a.txt', 'r', encoding='utf-8') as f:
# print(f.read()) # 一次性读取文件的所有数据,并且光标在文件的末尾,如果在去读,就读不到了
# print(f.read())
# 文件句柄f是支持for循环的
for line in f:
# line: 就是文件的一行内容
print(line)
# 了解的方法:
# f.flush() # 把数据从内存中立刻刷到磁盘
"""
当你读取的数据比较小的时候,其实是在缓冲区的,当数据量够多的时候,它会一定刷到磁盘
"""
"""
一次性读取文件的所有数据有什么问题:
当数据比较多的时候,会出现内存溢出,这种情况是坚决不能出现的
如何优化以上操作:
一点一点的读取数据然后把数据赶紧刷到硬盘里
"""
多用户的注册功能和多用户数据情况下的登录功能
多用户的注册:
1. 可以在程序不结束的情况下注册多个用户
2. 需要验证用户名不能重复
3. 注册的多用户的用户名和密码如何存储?
# 放在一个文件中,只不过是换行存储
while True:
# 1. 用户输入用户名和密码
username = input('username:').strip()
password = input('password:').strip()
'''我们需要验证用户名是否已经存在?'''
# 4. 读取文件内的数据,然后一行一行拿到每个用户名,然后做比较
with open('userinfo.txt', 'r', encoding='utf-8') as f:
# 逐行读取数据
for line in f:
# line:kevin|123
real_username, real_password = line.split('|') #
# 判断
if real_username == username:
print('用户名已经存在')
break
else:
# 2. 组织数据成特殊的格式
data = '%s|%s\n' % (username, password)
# 3. 把用户名和密码写入到文件中
with open('userinfo.txt', 'a', encoding='utf-8') as f:
f.write(data)
print('%s 注册成功' % username)
多用户的登录功能
# 2. 读取文件的数据比较密码
with open('userinfo.txt', 'r', encoding='utf-8') as f:
# read readline
# 循环逐行读取用户名和密码
for line in f:
# line : jerry|123
real_username, real_password = line.split('|') # ['jerry', '123\n']
# print(real_username, real_password)
# 比较用户名和密码
if real_username == username and password == real_password.strip('\n'):
print('登录成功')
break
else:
print('用户名或者密码不正确')
整合代码
"""
代码启动之后,给用户展示功能编号
1. 注册功能
2. 登录功能
"""
while True:
print("""
1. 注册功能
2. 登录功能
""")
cmd = input('请输入你要执行的功能编号:').strip()
if not cmd.isdigit():continue
if cmd == '1':
while True:
# 1. 用户输入用户名和密码
username = input('username:').strip()
password = input('password:').strip()
'''我们需要验证用户名是否已经存在?'''
# 4. 读取文件内的数据,然后一行一行拿到每个用户名,然后做比较
with open('userinfo.txt', 'r', encoding='utf-8') as f:
# 逐行读取数据
for line in f:
# line:kevin|123
real_username, real_password = line.split('|') #
# 判断
if real_username == username:
print('用户名已经存在')
break
else:
# 2. 组织数据成特殊的格式
data = '%s|%s\n' % (username, password)
# 3. 把用户名和密码写入到文件中
with open('userinfo.txt', 'a', encoding='utf-8') as f:
f.write(data)
print('%s 注册成功' % username)
elif cmd == '2':
username = input('username:>>>').strip()
password = input('password:>>>').strip()
# 2. 读取文件的数据比较密码
with open('userinfo.txt', 'r', encoding='utf-8') as f:
# read readline
# 循环逐行读取用户名和密码
for line in f:
# line : jerry|123
real_username, real_password = line.split('|') # ['jerry', '123\n']
# print(real_username, real_password)
# 比较用户名和密码
if real_username == username and password == real_password.strip('\n'):
print('登录成功')
break
else:
print('用户名或者密码不正确')
文件的操作模式
1. 文本模式
t:text
# r w a =====> rt wt at
"""
with open('userinfo.txt', 'r', encoding='utf-8') as f:
文本模式默认就是操作字符串,文本
特征:
1. encoding参数必须指定
2. 读取的所有的数据都是以字符串为单位的
3. t模式只能够读取文本或者字符模式
"""
2. 二进制模式
b模式:binary
with open('userinfo.txt', 'rb') as f:
"""
b模式中得b不能省略------------> rb wb ab
特征:
1. encoding='utf-8'参数不能够指定
2. 读取的数据全部以字节为单位
3. 二进制模式可以读取任意类型的文件
"""