1. 文件操作
1.计算机数据的存储
计算机的存储系统分为运行内存和硬盘两种
运行内存:用来保存程序运行过程中产生的数据,程序运行结束后会自动销毁
硬盘 :用来保存文件,保存在文件中的数据就是保存在硬盘中的,除非手动删除,否则数据会一直在
2.数据持久化
数据持久化就是将数据以各种形式保存在硬盘中(保存到本地文件中)
3.文件操作
文件操作基本步骤:打开文件 -> 操作文件(读、写) -> 关闭文件
打开文件
open(file, mode='r', encoding=None) - 以指定的模式打开指定的文件,并且返回一个文件对象
说明:
file - 文件路径,字符串类型
绝对路径:文件或者文件夹的全路径(一般不写绝对路径)
相对路径:只写文件绝对路径的一部分,另一部分用特殊符号代替
特殊符号:./ -> 表示当前路径 (可以省略)
../ -> 表示当前目录的上层目录
.../
mode - 打开方式,字符串类型
第一组:控制操作类型:
r - 以只读的方式打开文件(默认值)
w - 以只写的方式打开文件,打开前会先清空原文件的内容
a - 以只写的方式打开文件,不会清空
第二组:控制数据类型(文本数据-str/二进制数据-bytes):
t - 操作的数据是文本数据(默认值)
b - 操作的数据是二进制数据
注意:每一组只选一个,两组值进行组合使用
encoding - 文本编码方式;直接写'utf-8'
注意:如果打开方式中带b,就不能设置encoding
close()
open('/Users/zhangzhishuai/Desktop/千峰/01语言基础/day14-文件操作/files/text.txt')
open('./files/text.txt')
2.文件操作的读写操作
1.打开文件方式一:
文件对象 = open()
操作文件对象
文件对象.close
with open(文件路径, 文件打开方式, encoding=文本编码方式) as 文件对象:
操作文件对象
f = open('files/text.txt', encoding='utf-8')
print(f.read())
f.close()
with open('files/text.txt', encoding='utf8') as f:
print(f.read())
2.文件读操作
1)文件对象.read() - 从文件读写位置开始,读到文件的结尾(默认情况下读写位置在开头)
2)文件对象.readline() - 读文本文件的一行内容,从当前读写位置读到一行的结束
3)文件对象.readline() - 一行一行的读,读完为止,返回的是一个列表,列表元素是每一行的内容
with open('text2.txt', 'r', encoding='utf8') as f:
print('第一次', f.read())
print('第二次', f.read())
with open('text2.txt', 'r', encoding='utf8') as f:
print('第一次', f.readline())
print('第er次', f.readline())
3.数据持久化
1.数据持久化的基本操作
a. 数据保存在文件中
b.需要数据时候从文件中取读数据
c.当数据发生改变的时候,对保存数据的文件进行更新
注意:如果以读的方式打开一个不存在的文件,会报错,如果是以写的方式打开一个不存在的文件,不会报错,而且会自动新建这个文件
练习:写一个程序,统计这个程序启动的次数
with open('text2.txt', encoding='utf8') as f:
count = int(f.read())
count += 1
print(count)
with open('text2.txt', 'w', encoding='utf8') as f:
f.write(str(count))
4.字典和列表的数据持久化
names = [{'name': '张三', 'age': '34', 'tel': 213},
{'name': '张三', 'age': '34', 'tel': 213},
{'name': '张三', 'age': '34', 'tel': 213}
]
#1.字典和列表的写操作 先将列表或字典转换成字符串
with open('text2.txtf', 'w', encoding='utf-8') as f:
f.write(str(names))
#2.字典和列表的读操作
with open('text2.txt', 'r', encoding='utf-8') as f:
content = f.read()
print(content)
print(type(content))
new_content = eval(content)
print(new_content)
print(type(new_content))
for item in new_content:
print(item)
def add_students():
name = input('姓名:')
age = input('age:')
tel = input('tel:')
stu = {'name': name, 'age': age, 'tel': tel}
with open('text2.txt', 'r', encoding='utf-8') as f:
all_students = eval(f.read())
all_students.append(stu)
with open('text2.txt', 'w', encoding='utf-8') as f:
f.write(str(all_students))
add_students()
5.json数据
1.什么是json
import json
1)存在的意义
json就是不同编程语言之间进行数据交流的一种通用格式
2)概念
json是一种数据格式
a.一个json有且只有一个数据
b.这个数据是json支持的数据类型的数据
3)json支持的数据类型
数字类型 字符串 布尔 数组 字典(对象) 空值(null)
数字类型:所有的数字对应的类型 支持科学计数法
字符串:只能是双引号引起来,支持转义字符
布尔:true false 都要小写
数组:相当于Python的列表
字典:相当于Python字典但是字典的key只能是字符串,{key1: value1, key2:value2...}
空值:null 相当于Python中的none
2.json转Python
json Python
数字类型 数字
字符串 字符串(可能会将双引号变成单引号)
布尔 布尔(小写变大写)
数组 列表
字典 字典
空值(null) 空值(none)
json.loads(字符串) : 将json格式的字符串转换成Python对应的数据(这的字符串的内容必须满足json格式)
3.Python转json
Python json
int/float 数字类型
字符串 字符串都变成双引号
布尔 布尔(大写变小写)
列表/元组 数组
字典 字典
None null
json.dumps(数据) : 将指定的Python数据转换成json格式的字符串
result = json.loads('"abc"')
print(result)
print(type(result))
result = json.dumps([1, 'qeq', True, None])
print(result)
print(type(result))