字符编码和Python代码操作文件
字符编码和Python代码操作文件
读写模式之a模式
# a模式 只追加模式
# 路径不存在:自动创建
with open(r'a.txt','a',encoding='utf8') as f:
pass
# 路径存在:不会清空文件 在文件末尾添加内容
with open(r'a.txt', 'a', encoding='utf8') as f:
f.write('\n今天周四了 马上又要放假了 好开心!')
"""
我们所学习的r w a读写模式都只能操作文本文件,其他模式需要用d模式
"""
文件操作方法
# 文件操作方法
# 1.读系列
with open(r'a.txt', 'r', encoding='utf8') as f:
# print(f.read()) # 一次性读取文件内所有的内容
# print(f.readline()) # 每次只读文件一行内容
# print(f.readlines()) # 读取文件所有的内容 组织成列表 每个元素是文件的每行内容
# print(f.readable()) # 判断当前文件是否具备读的能力
# 2.写系列
with open(r'a.txt','w',encoding='utf8') as f:
# f.write('克服一切困难 奥利给!') # 往文件内写入文本内容
# f.write(123) # 写入的内容必须是字符串类型
# f.writelines(['jason','kevin','tony']) # 可以将列表中多个字符串元素全部写入
# print(f.writable()) # True
# print(f.readable()) # False
f.flush() # 直接将内存内文件数据刷到硬盘 相当于ctrl+s
文件优化操作
with open(r'a.txt', 'r', encoding='utf8') as f:
# print(f.read()) # 一次性读取文件内所有的内容
# print(f.read()) # 一次性读取文件内所有的内容
# print(f.read()) # 一次性读取文件内所有的内容
"""
1.一次性读完之后 光标停留在了文件末尾 无法再次读取内容
2.该方法在读取大文件的时候 可能会造成内存溢出的情况
解决上述问题的策略就是逐行读取文件内容
"""
# for line in f: # 文件变量名f支持for循环 相当于一行行读取文件内容
# line
'''以后涉及到多行文件内容的情况一般都是采用for循环读取'''
课堂练习
1.简易版本的注册、登陆功能
普通要求(实现一次即可)
注册功能
获取用户名和密码组织成你喜欢的样子写入文件即可
登陆功能
获取用户名和密码然后比对是否与文件内用户数据一致
# 注册功能
# 1.获取用户用户名和密码
username = input('username>>>:').strip()
password = input('password>>>:').strip()
# 2.将用户名和密码组织成一个字符串
data = '%s|%s' % (username, password)
# 3.文件操作 写入数据
with open(r'userinfo.txt', 'w', encoding='utf8') as f:
f.write(data)
print('用户:%s 注册成功' % username)
# 登录功能
# 1.获取用户名和密码(先使用input获取用户输入的数据 然后strip()移除首尾空格 之后赋值给变量名username)
username = input('username>>>:').strip()
password = input('password>>>:').strip()
# 2.获取文件内真实的用户数据
with open(r'userinfo.txt','r',encoding='utf8') as f:
# 由于现在文件中只有一行内容 我们干脆直接读取完
data = f.read() # 'jason|jason123'
'''with子代码执行完之后的结果是可以在外面使用的'''
# 3.切割字符串获取真实的用户名和密码
res = data.split('|') # ['jason', 'jason123']
'''这里也可以直接使用解压赋值的操作 real_name,real_pwd = data.split('|')'''
# 4.比对数据
if username == res[0] and password == res[1]:
print('登录成功')
else:
print('用户名或密码错误')
进阶练习
# 多用户注册
# while True:
# # 1.获取用户用户名和密码
# username = input('username>>>:').strip()
# password = input('password>>>:').strip()
# # 2.将用户名和密码组织成一个字符串
# data = '%s|%s\n' % (username, password)
# # 2.1.判断用户名是否已存在
# with open(r'userinfo.txt', 'r', encoding='utf8') as f1:
# # 2.2.循环读取每一行用户数据
# for line in f1:
# # 2.3.获取每一行数据中的用户名
# real_name, real_pwd = line.split('|')
# # 2.4.判断用户名是否一致
# if username == real_name:
# print('用户名已存在')
# break
# else:
# # 3.文件操作 写入数据
# with open(r'userinfo.txt', 'a', encoding='utf8') as f:
# f.write(data)
# print('用户:%s 注册成功' % username)
# 多用户登录
# 1.获取用户名和密码(先使用input获取用户输入的数据 然后strip()移除首尾空格 之后赋值给变量名username)
username = input('username>>>:').strip()
password = input('password>>>:').strip()
# 2.获取文件内真实的用户数据
with open(r'userinfo.txt', 'r', encoding='utf8') as f:
for line in f:
# 3.切割字符串获取真实的用户名和密码
'''注意密码末尾有\n'''
real_name, real_pwd = line.split('|') # ['jason', 'jason123\n']
# 4.比对用户名和密码是否正确
if username == real_name and password == real_pwd.strip('\n'):
print('登录成功')
break
else:
print('用户名或密码错误')
代码整合
while True:
print("""
1.用户注册
2.用户登录
""")
choice = input('请输入您想要执行的功能编号>>>:').strip()
if choice == '1':
# 1.获取用户用户名和密码
username = input('username>>>:').strip()
password = input('password>>>:').strip()
# 2.将用户名和密码组织成一个字符串
data = '%s|%s\n' % (username, password)
# 2.1.判断用户名是否已存在
with open(r'userinfo.txt', 'r', encoding='utf8') as f1:
# 2.2.循环读取每一行用户数据
for line in f1:
# 2.3.获取每一行数据中的用户名
real_name, real_pwd = line.split('|')
# 2.4.判断用户名是否一致
if username == real_name:
print('用户名已存在')
break
else:
# 3.文件操作 写入数据
with open(r'userinfo.txt', 'a', encoding='utf8') as f:
f.write(data)
print('用户:%s 注册成功' % username)
elif choice == '2':
# 1.获取用户名和密码(先使用input获取用户输入的数据 然后strip()移除首尾空格 之后赋值给变量名username)
username = input('username>>>:').strip()
password = input('password>>>:').strip()
# 2.获取文件内真实的用户数据
with open(r'userinfo.txt', 'r', encoding='utf8') as f:
for line in f:
# 3.切割字符串获取真实的用户名和密码
'''注意密码末尾有\n'''
real_name, real_pwd = line.split('|') # ['jason', 'jason123\n']
# 4.比对用户名和密码是否正确
if username == real_name and password == real_pwd.strip('\n'):
print('登录成功')
break
else:
print('用户名或密码错误')
else:
print('没有改功能 爱咋滴咋滴!')
文件操作模式
t 文本模式
1.默认的模式
r w a >>> rt wt at
2.该模式所有操作都是以字符串基本单位(文本)
3.该模式必须要指定encoding参数
4.该模式只能操作文本文件
b 二进制模式
1.该模式可以操作任意类型的文件
2.该模式所有操作都是以bytes类型(二进制)基本单位
3.该模式不需要指定encoding参数
rb wb ab
二进制模式读写操作
# with open(r'a.txt','rb') as f:
# # print(f.read())
# print(f.read(6).decode('utf8'))
# with open(r'a.txt','r',encoding='utf8') as f:
# print(f.read())
# print(f.read(4))
"""
read() 括号内可以放数字
在t模式下表示字符个数
在b模式下表示字节个数
英文字符统一使用一个bytes来表示
中文字符统一使用三个bytes来表示
"""
文件内光标的移动
with open(r'b.txt', 'rb') as f:
print(f.read(4).decode('utf8'))
print(f.tell()) # 查看光标移动了多少个字节
f.seek(3, 1)
print(f.read().decode('utf8'))
"""
控制文件内光标的移动 f.seek()
f.seek(offset,whence)
offset表示位移量
始终是以字节为最小单位
正数从左往右移动
负数从右往左移动
whence表示模式
0:以文件开头为参考系(支持tb两种模式)
1:只支持b模式 以当前位置为参考系
2:只支持b模式 以文件末尾为参考系
"""
# 小练习:实现动态查看最新一条日志的效果
import time
with open('a.txt', 'rb') as f:
f.seek(0, 2)
while True:
line = f.readline()
if len(line) == 0:
# 没有内容
time.sleep(0.5)
else:
print(line.decode('utf-8'), end='')
文件的内容修改
# 方式1 覆盖
with open(r'c.txt','r',encoding='utf8') as f:
data = f.read()
# print(type(data)) >>> str
with open(r'c.txt','w',encoding='utf8') as f1:
new_data = data.replace('tony','jason')
f1.write(new_data)
1.不适合修改量大的文件
# 方式2 新建
import os
with open('c.txt', mode='rt', encoding='utf-8') as read_f, \
open('c.txt.swap', mode='wt', encoding='utf-8') as write_f:
for line in read_f:
write_f.write(line.replace('SB', 'kevin'))
os.remove('c.txt') # 删除原文件
os.rename('c.txt.swap', 'c.txt') # 重命名文件
1.需要插入模块才能实现删除功能
2.多创建一个文件
小练习
员工管理系统思路
1.整理今日内容并完成博客编写
2.熟练掌握课堂练习
普通版本 必会
进阶版本与封装版本掌握越快越好
3.写一个简易的拷贝工具
支持所有的文件类型
答案(2)
1.循环打印系统中拥有的功能
2.获取用户输入的功能编号并判断是否在已有功能中
3.先在循环外定义存储用户数据的列表(用户数据放在列表元素用字典形式)
4.先获取用户的编号
5.循环获取列表中每个用户字典 判断用户编号是否存在
6.存在则提示用户并重新打印全部功能
7.如果不存在则获取用户其他数据并组织成一个字典
8.最后添加到用户列表
# 1.简易版本的注册、登陆功能
# 普通要求(实现一次即可)
# 注册功能
# 获取用户名和密码组织成你喜欢的样子写入文件即可
# 登陆功能
# 获取用户名和密码然后比对是否与文件内用户数据一致
print('''
\33[31m1.用户注册
\33[32m2.用户登录
\33[33m3.删除用户
\33[34m4.退出用户''') # 定义系统的几个功能
while True:
# 1. 注册功能,添加用户,首先获取用户创建的信息,然后存入数据库
# 1.1 获取用户创建的信息
choice = input('\033[35m选择功能编号:').strip()
if choice == '1':
print('\33[31m——————进入用户注册功能!——————')
login_username = input('\33[31m请输入注册用户名:').strip()
login_password = input('\33[31m请输入注册密码:').strip()
# 1.2 将数据整合到一起
login_msg = f'{login_username}|{login_password}\n'
# 1.3 判断输入的注册信息是否在数据库中,需要读取数据库中的 用户名
with open(r'login_date.txt', 'r', encoding='utf8') as f1:
for line in f1:
read_date_username, read_date_password = line.split('|')
if login_username == read_date_username: # 1.4 如果在数据库,那就不行
print('\33[36m该用户已存在,请更换用户名以继续!')
break
else:
# 1.5 不在数据库,就需要将数据写入数据库中
with open(r'login_date.txt', 'a', encoding='utf8') as f2:
f2.write(login_msg)
print(f'\33[36m用户{login_username}注册成功')
elif choice == '2':
print('\33[32m——————进入用户登录功能!——————')
# 1. 获取用户输入的信息
inp_username = input('输入用户名:').strip()
inp_password = input('请输入密码:').strip()
login_msg1 = f'{inp_username}|{inp_password}'
# 2. 将数据库的信息读出来 跟用户输入的进行比对
with open(r'login_date.txt', 'r', encoding='utf8') as f3: # 读信息
for line in f3: # 把数据库内的数据一行一行的循环比对
read_date_username1, read_date_password1 = line.split('|')
if inp_username == read_date_username1:
print(f'\33[32m用户{read_date_username1}登录成功!')
break
else:
print('\33[31m未查询到此用户,请进行注册!')
elif choice == '3':
print('\33[33m用户删除')
elif choice == '4':
print('\33[34m退出程序')
else:
print('你个憨皮,未开通此功能!')
答案(3)
3.写一个简易的拷贝工具 ( 支持所有的文件类型 )
source_file = input('输入源文件路径:').strip()
destination_file = input('输入目标文件路径:').strip()
with open(rf'{source_file}','rb') as f1,open(rf'{destination_file}','wb') as f2:
for line in f1:
res = f2.write(line)
print(res)
字符编码和Python代码操作文件的更多相关文章
- 字符编码和python中的文件处理
字符编码与python文件处理 ---------------- 字符编码 1.常见的编码 ASCII: 美国人发明的,只编码英文字母和符号,1个字节. GB2312: 中国人发明的,增加了中文汉字和 ...
- 在Python中操作文件之truncate()方法的使用教程
在Python中操作文件之truncate()方法的使用教程 这篇文章主要介绍了在Python中操作文件之truncate()方法的使用教程,是Python入门学习中的基础知识,需要的朋友可以参考下 ...
- day06 python代码操作MySQL
day06 python代码操作MySQL 今日内容 python代码操作MySQL 基于python与MySQL实现用户注册登录 python操作MySQL python 胶水语言.调包侠(贬义词& ...
- 字符编码和python文件操作
字符编码和文件操作 目录 字符编码和文件操作 1. 字符编码 1.1 什么是字符编码 1.2 字符编码的发展史 1.2.1 ASCII码 1.2.2 各国编码 1.2.3 Unicode 1.3 字符 ...
- python 关于操作文件的相关模块(os,sys,shutil,subprocess,configparser)
一:os模块 os模块提供了许多允许你程序与操作系统直接交互的功能 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname&quo ...
- 字符编码codecs模块(读写文件)
python对多国语言的处理是支持的很好的,它可以处理现在任意编码的字符,这里深入的研究一下python对多种不同语言的处理.有一点需要清楚的是,当python要做编码转换的时候,会借助于内部的编码, ...
- python关于操作文件的相关模块(os,sys,shutil,subprocess,configparser)
一:os模块 os模块提供了许多允许你程序与操作系统直接交互的功能 功能 说明 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirna ...
- 字符编码和python使用encode,decode转换utf-8, gbk, gb2312
ASCII码 标准ASCII码使用7位二进制数表示大写或小写字母,数字0到9标点符号以及在美式英语中使用的特殊控制字符. 在标准ASCII码中,最高位(b7)用作奇偶校验位,所谓奇偶校验,是指在代码传 ...
- 字符编码到python编辑器流程
字符(存储了信息的东西)编码(): 键盘发送的是电流-->主机(内存)接受到电流(当作010100110101)-->显示屏 接受电流(当作010100110101------->键 ...
随机推荐
- python 面向对象:封装---对象的属性可以是另一个类创建的对象
# 对象封装:对象的属性可以是另一个类创建的对象 # 案例需求: # 1.士兵许三多有一把AK47 # 2.士兵用枪射击标靶 # 3.枪能装填和发射子弹 class Gun: # 分析: # 枪的属性 ...
- [flask] jinja自定义filter来过滤html标签
问题描述 数据库存储了html格式的博客文章,在主页(index)显示的时候带有html标签,如何过滤掉呢? 解决方案 用jinja自定义filter过滤掉html标签 我是用的工厂函数,因此在工厂函 ...
- Go语言系列之知识框架
一.Go基础入门知识 二.变量和基本数据类型 三.流程控制语句 四.数组和切片 五.map的声明和使用 六.函数func方法 七.指针和地址 八.结构体 九.接口interface 十.并发神器gor ...
- FastDFS的应用
一.定义 FastDFS是由淘宝的余庆先生所开发的一个轻量级.高性能的开源分布式文件系统.用纯C语言开发,功能丰富: 文件存储 文件同步 文件访问(上传.下载) 存取负载均衡 在线扩容 适合有大容量存 ...
- HW防守 | Linux应急响应基础
最近也是拿到了启明星辰的暑期实习offer,虽然投的是安服,但主要工作是护网,昨天在公众号Timeline Sec上看到有一篇关于护网的文章,所以在这里照着人家写的在总结一下,为将来的工作打点基础. ...
- 小程序onShareAppMessage有点迷
小程序遇到的问题 起因 目前项目需求是分享时携带参数去进行裂变,但是在查看微信文档后发现有onShareAppMessage这个页面处理事件可以使用.事件可以使用return一个Object,用于自定 ...
- Choregraphe 2.8.6.23动作失效
动作和动画执行完以后,无法自动还原成默认状态,自然接下来动作无法执行了.之后各种操作可能诱发软件原有的bug.需要开关自主生活模块才能恢复. 部分连贯的动作不需要恢复就能执行,动画不行. 站立动作好像 ...
- Python实现自动更改系统用户密码,生成随机密码
算是一个实用的例子,定制系统任务,并将随机密码上传至日志服务器,实现定期修改密码: 部分代码: 1 #!/usr/bin/env python 2 #coding:utf-8 3 import ran ...
- java-异常-原理异常对象的抛出throw
1 class Demo { 2 public static int method(int[] arr,int index) { 3 4 // System.out.println(arr[index ...
- python04day
回顾 int str bool str: s1='tangdaren123' 索引: s1[0] s1[-1] s1[:3] s1[:5:2] s1[-1:-4:-1] s1[-1:-6:-2] 常用 ...