Python3学习之路~5.7 Json & pickle 模块

用于序列化的两个模块

  • json,用于字符串 和 python数据类型间进行转换
  • pickle,用于python特有的类型 和 python的数据类型间进行转换

Json模块提供了四个功能:dumps、dump、loads、load

pickle模块提供了四个功能:dumps、dump、loads、load

json.dumps 将数据通过特殊的形式转换为所有程序语言都认识的字符串

json.dump 将数据通过特殊的形式转换为所有程序语言都认识的字符串,并写入文件

pickle.dumps 将数据通过特殊的形式转换为只有Python语言认识的字符串

pickle.dump 将数据通过特殊的形式转换为只有Python语言认识的字符串,并写入文件

Json序列化举例:

# json是所有语言中都通用的,适用于不同语言进行数据交互。
# 但json只能处理简单的数据类型,如果要处理复杂的,可以使用pickle
# 应用场景举例:当你使用虚拟机(或者玩游戏)时,中间你突然有点别的事情,于是要将虚拟机挂起,以便下次使用时还是现在的状态。
# 于是就用到了json,json序列化将虚拟机目前的状态(比如进行了什么操作,打开了什么文件)保存在文件中,
# 当你干完别的事,再次启动虚拟机时,json反序列化会将文件中保存的状态从文件中读出来,于是你就可以继续上次的操作了。

# dump和load配合使用可以实现序列化和反序列化,
# 在Python2中可以dump很多次,也可以load很多次,他们一一对应,但是其实这没什么意义
# 但在Python3中,可以dump很多次,但是当dump多次时,load会报错,所以记住在Python3中永远不要dump多次
import json
info = { "name":"Alex", "age":22 }

with open(‘text.txt‘,‘w‘,encoding=‘utf-8‘) as f:
    #f.write(info) #报错,字典不能写入文件中,字符串能写入文件中
    #f.write(str(info)) #太low了
    print(type(json.dumps(info)))  # <class ‘str‘>
    #f.write( json.dumps(info) ) # 高级做法1
    json.dump(info,f)  # 高级做法2,同上

json序列化.py

import json
with open(‘text.txt‘,‘r‘,encoding=‘utf8‘) as f:
    #data=json.loads(f.read())
    data=json.load(f) #同上
    print(data["age"])

json反序列化.py

pickle序列化举例:

# pickle写进文件中的貌似是一段乱码,其实不然,这是pickle自己的一套语法规则,当然这也不是加密
# pickle可以序列化所有的数据类型
# 但是pickle只能在Python中使用,别的语言不认识它

import pickle
def sayhi(name):
    print("Hello ",name)

info = { "name":"Alex", "age":22, ‘func‘:sayhi }

with open(‘text2.txt‘,‘wb‘) as f:
    print(type(pickle.dumps(info)))  # <class ‘bytes‘>
    f.write( pickle.dumps(info) ) # sayhi是一个内存地址,用json序列化就写不到文件中,会报错

pickle序列化.py

import pickle
# def sayhi(name):
#     print("Hello2 ",name)

with open(‘text2.txt‘,‘rb‘) as f:
    data=pickle.loads(f.read()) # 报错
    print(data)
    # data["func"](‘alex‘)
# AttributeError: Can‘t get attribute ‘sayhi‘ on <module ‘__main__‘ from ‘D:/python-study/s14/Day04/pickle反序列化.py‘>
# 为什么报错呢?因为sayhi是一个内存地址,当pickle序列化.py程序执行完之后,这个地址就被释放了,当然我们就找不到了。
# 这里只是想说明一点:pickle可以序列化所有的数据类型,不管这个数据是否可被反序列化
# 如果想要不报错,可以把sayhi函数的定义拷贝过来,而且还可以执行这个函数
# 只要保证函数名相同就不会报错,函数体可以完全不一样

pickle反序列化.py

json模块的作用之一:根据字符串书写格式,将字符串自动转换成相应格式

import json

# Python3.x中input方法获取到的都是字符串,相当于Python2.x中的raw_input
inp_str = input("请输入:") # 输入一个列表,[1,2,3]
print(type(inp_str)) # <class ‘str‘>
inp_str = json.loads(inp_str,encoding="UTF-8") # 根据字符串书写格式,将字符串自动转换成 列表类型
print(type(inp_str),inp_str[0]) # <class ‘list‘> 1

inp_str = input("请输入:") # 输入一个字典,{"name":"Rose","age":21,"sex":"F"}
                             # 切记,字典内部必须是 双引号 !!!单引号会报错。
print(type(inp_str)) # <class ‘str‘>
inp_str = json.loads(inp_str,encoding="UTF-8") # 根据字符串书写格式,将字符串自动转换成 字典类型
print(type(inp_str),inp_str[‘name‘],inp_str[‘age‘],inp_str[‘sex‘]) # <class ‘dict‘> Rose 21 F

原文地址:https://www.cnblogs.com/zhengna/p/9214286.html

时间: 2024-08-02 14:26:20

Python3学习之路~5.7 Json & pickle 模块的相关文章

java痛苦学习之路[十二]JSON+ajax+Servlet JSON数据转换和传递

1.首先客户端需要引入 jquery-1.11.1.js 2.其次javaweb工程里面需要引入jar包  [commons-beanutils-1.8.0.jar.commons-collections-3.1.jar.commons-lang-2.4.jar.commons-logging-1.1.3.jar.ezmorph-1.0.6.jar.json-lib-2.3-jdk15.jar] 3.客户端js端代码 4.servlet 服务器,映射的路径CardColl 以上就是整个过程,如果

Python学习笔记——基础篇【第五周】——json &amp; pickle 模块

json & pickle 模块(序列化) 用于序列化的两个模块 json,用于字符串 和 python数据类型间进行转换 pickle,用于python特有的类型 和 python的数据类型间进行转换 Json模块提供了四个功能:dumps.dump.loads.load pickle模块提供了四个功能:dumps.dump.loads.load dumps和dump区别: pickle.dump(info,f) #print(pickle.dumps(info)) #f.write(pick

Python学习之路:time和datetime模块

转自:http://blog.51cto.com/egon09/1840425 一:内建模块 time和datetime(http://www.jb51.net/article/49326.htm) 在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 3)元组(struct_time)共九个元素.由于Python的time模块实现主要调用C库,所以各个平台可能有所不同. UTC(Coordinated Universal Time,世界协调时)亦即格林威治天文时间,

json&amp;pickle模块shelve模块

json 在不同的编程语言之间传递对象 1 dic = {'name': 'alvin', 'age': 23, 'sex': 'male'} 2 print(type(dic)) # <class 'dict'> 3 4 j = json.dumps(dic) 5 print(type(j)) # <class 'str'> 6 7 f = open('序列化对象', 'w') 8 f.write(j) # -------------------等价于json.dump(dic,

Python常用模块——json,pickle模块

什么是序列化? 序列化是指把内存里的数据类型转变成字符串,使其能存储到硬盘或通过网络传输到远程,因为硬盘或网络传输时只能接收bytes. 为什么要序列化? 我们编写的程序,会涉及到各种各样的对象.数据结构,它们通常是以变量的形式在内存中存在着.当程序运行结束后,这些变量也就会被清理.但我们有时希望能够在下一次编写程序时恢复上一次的某个对象(如机器学习中的到结果,需要程序运行较长时间,多次运行时间成本太大),这就需要我们将变量进行持久化的存储.一种方式是利用文件读写的方式将变量转化为某种形式的字符

python json,pickle模块

json模块 不同语言间的数据交互 eval方法可以将一个字符串转成python对象,但eval方法是有局限性,对于普通的数据类型,json.loads和eval都能用,但遇到特殊类型(函数.类等)的时候,eval就不管用了,因此eval通常用来执行一个字符串表达式,并返回表达式的值. dic='{"name":"alex"}' f=open('hello','w') f.write(dic) #eval方法将字符串转换为python的数据类型 f_read=ope

os模块,sys模块,json / pickle模块,logging模块

目录 OS模块 sys模块 json和pickle模块 序列化和反序列化 json模块 pickle logging模块 OS模块 能与操作系统交互,控制文件 / 文件夹 # 创建文件夹 import os os.mkdir(r'D:\py_case\test') # 删除文件夹 os.rmdir(r'D:\py_case\test') # # 列出指定目录下所有文件和子目录 (子目录文件不会列出来) res = os.listdir(r'D:\pycharm_project\Test') pr

json&amp;pickle模块、configparse/hashlib/subprocess 模块

一.json 与pickle模块 序列化: 1.什么是序列化&反序列化 内存中的数据类型---->序列化---->特定的格式(json格式或者pickle格式) 内存中的数据类型<----反序列化<----特定的格式(json格式或者pickle格式) 2.为何要序列化 序列化得到结果=>特定的格式的内容有两种用途 1.可用于存储=>用于存档 2.传输给其他平台使用=>跨平台数据交互 ? 强调: 针对用途1的特定一格式:可是一种专用的格式=>pick

python3学习之路(目录)

一.Python学习(第一章) 1.python入门 -->第一个python程序 -->注释 -->变量 -->输入输出 -->流程控制 -->while循环 -->练习题 2.运算符 -->算数运算 -->比较运算 -->赋值运算 -->逻辑运算 -->成员运算 3.基本数据类型 -->整型 -->布尔型 -->字符串 -->列表 -->元组 -->字典 -->练习题 目录 持续更新中..