DAY-12总结

1. 数据持久化(数据本地化)

保存在程序中的数据是保存在运行内存中的,当程序运行结束,内存会自动释放,数据也会消失;
如果不希望数据随着程序的结束而消失,就需要将数据通过文件存储到硬盘里面
程序中经常用来保存数据的文件有: 数据库文件(db,sqlite); json文件; plist文件; txt文件等;
png文件、jpg文件、gif文件...mp4文件、mov文件等、MP3等...

2. 文件操作(操作文件中的内容)

2.1 步骤: 打开文件 -> 操作文件内容(读操作、写操作) -> 关闭文件

a. 打开文件:

open(file, mode='r',encoding=None)   -  以指定的方式打开指定文件并且返回文件对象

b. 说明:

file  -  字符串; 文件在电脑中的地址(文件路径)
     路径可以写绝对路径也可以写相对路径
     绝对路径 - 文件在电脑中的完整路径
     相对路径 - ./代表当前目录(./可以省略)
     ../代表当前目录的上层目录
     .../代表当前目录的上层目录的上层目录
注意: 当前目录指的是当前py文件所在的目录

mode - 字符串; 文件的打开方式,决定打开文件后能够对文件做什么以及读写的数据类型
'r'/'rt'/'tr' - 以只读的方式打开文件; 读出来的内容是字符串
'rb'/'br' - 以只读的方式打开文件;读出来的内容是二进制数据(bytes)
'w'/'wt'/'tw' - 以只写的方式打开文件; 将字符串写入文件; 会清空原文件
'wb'/'bw' - 以只写的方式打开文件;将二进制写入文件
'a'/'at'/'ta' - 以只写的方式打开文件; 将字符串写入文件; 不会清空原文件,追加
'ab'/'ba' - 以只写的方式打开文件; 将二进制写入文件; 不会清空原文件,追加
encoding - 字符串;设置文本文件的编码方式(只针对文本文件有效);一般使用'utf-8'

注意:

1.同一个文件读和写的编码方式一样

2.指针文本文件的文本操作有效, 所有带'b'的打开方式都不能设置
encoding

2.2 关闭文件

文件对象.close()

a.绝对路径

open(r'/Users/yuting/Workspace/JAVA/授课/python1904/语言基础/day12-文件操作和异常处理/test1.txt')

b.相对路径

open('./test1.txt')
open('test1.txt')

c.打开文件

f = open('test1.txt', 'r', encoding='utf-8')
print(f)

3. 读写操作

3.1 读操作

文件对象.read()    -   获取整个文件的内容,以字符串或者二进制的形式返回
文件对象.readline()  -  获取文本文件中一行的内容,以字符串或者二进制的形式返回

3.2 写操作

文件对象.write(内容) - 将内容写入到指定的文件中
f = open('test1.txt', 'r', encoding='utf-8')
# content = f.read()
# print(content)

content = f.readline()
print('按行读1:', content)
content = f.readline()
print('按行读2:', content)

f.seek(0)    # 移动光标到文件开头
print(f.read())

f.close()

# 文件写操作
f = open('test1.txt', 'a', encoding='utf-8')
f.write('abc')

3.3 with - open

打开文件,在文件作用域中对文件进行操作。离开文件作用域文件自动关闭

语法:

    with open(file, mode='r', encoding=None) as 文件对象:
        文件作用域(操作文件)
import requests
with open('./files/test3.txt', encoding='utf-8') as f:
    # print(f.readline())
    # print(f.readline())
    while True:
        line = f.readline()
        if not line:
            break
        print(line)
# print(f.readline())   # ValueError: I/O operation on closed file.

3.4 打开不存在的文件

以读的方式打开不存在的文件: 程序会出现FileNotFoundError异常
以写的方式打开不存在的文件:不会出现异常,并且会创建一个空的文件
# open('files/test4.txt', 'r')  # FileNotFoundError: [Errno 2] No such file or directory: 'files/test4.txt'
# open('files/test4.txt', 'rb')  # FileNotFoundError: [Errno 2] No such file or directory: 'files/test4.txt'
open('files/test7.txt', 'ba')

3.5 二进制文件的读写

a. 普通文本文件: 可以使用带t或者带d的读写方式去打开
b. 二进制数据文件: 视频文件、音频文件、图片都是二进制文件,这些文件只能用带b的打开方式去打开

with open('files/test3.txt', 'rb') as f:
    content = f.read()
    # print(type(content))    # <class 'bytes'>


with open('files/shanji.jpeg', 'rb') as f:
    content = f.read()
    print(content)


with open('new_shanji.jpeg', 'wb') as f:
    f.write(content)


response = requests.get('https://www.baidu.com/img/bd_logo1.png')
with open('baidu.png', 'wb') as f:
    f.write(response.content)

4. 怎么做到数据的持久化

a. 将数据保存到本地文件
b. 需要这个数据的时候不是直接赋值而是从本地文件中去取值
c. 当数据值发生改变后,将最新的数据更新到文件中

# 练习: 统计当前程序运行的次数
# num = 1
# print(num)
# num += 1
with open('files/count.txt', 'r', encoding='utf-8') as f:
    num = int(f.read())

num += 1
print('第%d次运行程序' % num)

with open('files/count.txt', 'w', encoding='utf-8') as f:
    f.write(str(num))

4.1 eval的使用

将序列字符串转换成序列

str1 = '{}'
dict1 = eval(str1)
print(type(dict1))

str2 = "{'a': 1,  'b': 2}"
dict2 = eval(str2)
print(type(dict2), dict2['a'], dict2['b'])

str3 = '[10, 20, 30]'
list1 = eval(str3)
print(type(list1), list1)

str4 = "[{'name': '小明', 'age': 20}, {'name': 'xiaohua', 'age': 18}]"
list2 = eval(str4)
print(type(list2), len(list2))
# 练习: 注册账号,并且打印当前已经注册过的账号
# users = {}
with open('files/users', 'r', encoding='utf-8') as f:
    users = eval(f.read())

while True:
    user_name = input('用户名:')
    pw = input('密码:')
    users[user_name] = pw

    value = input('是否继续(y/n):')
    if value == 'n':
        break

print(users)
with open('files/users', 'w', encoding='utf-8') as f:
    f.write(str(users))

注意: json模块是python内置的模块,模块主要提供和json操作相关的函数

import json
import requests

5. 什么是json数据

json是一种通用的数据格式;几乎所有的高级语言都支持将json数据转换成当前语句数据,也支持将当前语言数据转换成json数据;
一般数据接口提供的数据都是json格式的数据

5.1 json格式

json格式: a.一个json有且只能有一个数据 b.这个数据必须是json支持的数据类型的数据
json支持的数据类型:
数字类型 - 包括所有的数字,例如: 100, 12.5, -34, -2.13, 3e3(支持科学计数法)
字符串 - 用双引号引起来的字符集, 例如: "abc", "123", "abc123", "abc\n123", "\u4e00"
布尔值 - 只有true和false两个值
数组 - 相当于python中的列表: [100, "你好", true, [1, 2]]
字典 - 相当于python中的字典, key必须是字符串: {"b": 100, "a": true}
空值 - null; 相当于Python中的None,表示空和没有

5.2 将json数据转换成python数据

a. 对应关系

    json                                         python
数字类型                                   int/float
字符串                                 str, 双引号可能会变成单引号
布尔值                                 bool, true -> True; false -> False
数组                                               list
字典                                              dict
空值                                       null -> None

b. 转换方法
json模块中有一个loads可以将json格式的数据转换成python对应的数据
loads(字符串) - 将json格式的字符串转换成python数据
注意: 这儿的字符串的内容必须是json数据

import json
import requests
result = json.loads('100')
print(type(result), result)

# result = json.loads('abc')  json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)
result = json.loads('"abc"')
print(type(result), result)

result = json.loads('true')
print(type(result), result)

result = json.loads('[100, "abc", false, null]')
print(type(result), result)

response = requests.get('https://www.apiopen.top/satinApi?type=1&page=1')
# print(type(response.text), response.text)
result = json.loads(response.text)
print(type(result), result)
for dict1 in result['data']:
    print(dict1['name'])

5.3 将python数据转换成json

a. 转换关系
    python                                      json
int、float                                      数字
str                                     字符串, 引号都会变成双引号
bool                                 布尔,True -> true; False -> false
list、tuple                                   数组
dict                                                    字典
None                                                  null

b. 转换方法
dumps(数据) - 将括号中的python数据转换成json格式的字符串

result = json.dumps([100, 'abc', True, None])
print(type(result), result)   # <class 'str'> [100, "abc", true, null]
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容