python全栈开发 * 24 知识点汇总 * 180705
24 模块
-------序列化
一.什么是模块 模块:py文件就是一个模块.
二.模块的分类:
(1)内置模块 (登录模块,时间模块,sys模块,os模块)
(2)扩展模块 (itchat 微信有关,爬虫,beautiful soup 网址(http://pypi.org)
(3)自定义模块
三.序列化模块及分类.
1创造一个序列化字符串
2.序列化模块分类
(1).json 适用于不同语言之间,但可支持数据类型有限,str,int,list,dict,bool 作用:方便数据传输 .
(2).pickle 只用于python语言之间的传输,可支持python所有的数据类型
(3)shelve 只是python的一个小工具(文件方面)
3.json 的用法
(1).json的意义 a.数据通过网络发送给别人;
b.写入文件也用到json
(2)dumps,loads (将数据用于网络传输 ; 多个数据写入一个文件)
网络传输:
import json
dic={"alex":["男","中国",1000]}
ret=json.dumps(dic)
ret1=json.dumps(dic,ensure_ascii=False)
print(ret,type(ret)) # {"alex": ["\u7537", "\u4e2d\u56fd", 1000]} <class 'str'>
print(ret1,type(ret1)) #{"alex": ["男", "中国", 1000]} <class 'str'>
ret2=json.loads(ret)
print(ret2,type(ret2)) # {'alex': ['男', '中国', 1000]} <class 'dict'>
文件操作: 多个数据写入一个文件
import json
dic={"alex":["男","中国",1000]}
l1=["包宝宝","包大宝宝","包小宝宝","包老宝宝","真的很好看"]
dic1 = {"alex": ('women','women','老女人')}
f=open("json1",encoding="utf-8",mode="w")
s1=json.dumps(dic,ensure_ascii=False)
f.write(s1+"\n")
s2=json.dumps(dic1,ensure_ascii=False)
f.write(s2+"\n")
s3=json.dumps(l1,ensure_ascii=False)
f.write(s3+"\n")
f.close() # 写文件
f1=open("json1",encoding="utf-8") # 读文件
for line in f1: #{'alex': ['男', '中国', 1000]} <class 'dict'>
ret=json.loads(line) #{'alex': ['women', 'women', '老女人']} <class 'dict'>
print(ret,type(ret)) # ['包宝宝', '包大宝宝', '包小宝宝', '包老宝宝', '真的很好看'] <class 'list'> (3)dump,load (单个数据写入一个文件)
import json
dict={'alex':["男",1000,"中国"]}
f=open("json1",encoding="utf-8",mode="a")
json.dump(dict,f,ensure_ascii=False) # 写文件
f.close()
f1=open("json1",encoding="utf-8") # 读文件
ret=json.load(f1)
print(ret,type(ret)) # {'alex': ['男', 1000, '中国']} <class 'dict'>
(4).json的缺点,将数据写入文件时只能写一个,如果将多个序列化字符串写入文件,反序列化会出错.(dump.load)
(5).json的其他参数
sort_keys=True( 按首字母的ascii码的位置排序)
ensure_ascii 显示中文
indent=2 key 的缩进为2
separators=(",",":") "," 键值对之间的分割符,":"键与值之间的分割符.
(6).特别注意: 字典序列化为字符串,key 必须是字符串类型,数字会变为字符串.
4.pickle 的用法
(1)dumps loads 用于网络传输
import pickle
dic={"包宝宝":["包大宝宝","包小宝宝","包老宝宝","真的很好看"]}
ret=pickle.dumps(dic)
print(ret,type(ret)) # <class 'bytes'>
ret2=pickle.loads(ret)
print(ret2,type(ret2)) # {'包宝宝': ['包大宝宝', '包小宝宝', '包老宝宝', '真的很好看']} <class 'dict'> (2)dump load 文件操作
单个数据写入一个文件:
import pickle
dic={"包宝宝":["包大宝宝","包小宝宝","包老宝宝","真的很好看"]}
f=open("pickle",mode="wb")
pickle.dump(dic,f)
f.close()
f1=open("pickle",mode="rb")
ret=pickle.load(f1)
print(ret,type(ret)) #{'包宝宝': ['包大宝宝', '包小宝宝', '包老宝宝', '真的很好看']} <class 'dict'>
多个数据写入一个文件:
import pickle
dic={"包宝宝":["包大宝宝","包小宝宝","包老宝宝","真的很好看"]}
dic1={'alex':["男",1000,"中国"]}
dic2 = {"alex1": ('women','women','老女人')}
f1=open("pickle1",mode="wb")
pickle.dump(dic,f1)
pickle.dump(dic1,f1)
pickle.dump(dic2,f1)
f1.close()
f2=open("pickle1",mode="rb")
# print(pickle.load(f2)) # {'包宝宝': ['包大宝宝', '包小宝宝', '包老宝宝', '真的很好看']}
# print(pickle.load(f2)) # {'alex': ['男', 1000, '中国']}
# print(pickle.load(f2)) # {'alex1': ('women', 'women', '老女人')}
while True:
try:
print(pickle.load(f2))
except EOFError:
break
5.shelve 的用法 与文件相关,只能在python中用.
给文件写入一个键值对; 并输出键值对的值
import shelve
f = shelve.open('shelve_file')
f['key'] = {'int':10, 'float':9.5, 'string':'Sample data'} #直接对文件句柄操作,就可以存入数据
f.close()
f1 = shelve.open('shelve_file')
existing=f1["key"] #{'int': 10, 'float': 9.5, 'string': 'Sample data'}
f1.close()
print(existing)
#给key的值(字典)添加一个键值对.
import shelve
f2 = shelve.open('shelve_file',writeback=True) # writeback允许给文件加值
f2['key']['new_value'] = 'this was not here before'
print(f2['key'])
f2.close()
python全栈开发 * 24 知识点汇总 * 180705的更多相关文章
- python全栈开发 * 10知识点汇总 * 180612
10 函数进阶 知识点汇总 一.动态参数 形参的第三种1.动态接收位置传参 表达:*args (在参数位置编写 * 表⽰接收任意内容) (1)动态位置参数def eat(*args): print(a ...
- python全栈开发 * 32知识点汇总 * 180717
32 网络编程 (一)一.架构 定义:程序员开发的一种模式. 分类: C/S 架构 C/S即:Client与Server , 客户端/ 服务器模式 . 缺点 : 冗余 B/S 架构 Browser与S ...
- python全栈开发 * 12 知识点汇总 * 180530
12 知识点总结 装饰器进阶 ⼀. 通⽤装饰器的回顾1.开闭原则: 对增加功能开放. 对修改代码封闭2.装饰器的作⽤: 在不改变原有代码的基础上给⼀个函数增加功能3.通⽤装饰器的写法:def wrap ...
- python全栈开发 * 01知识点汇总 * 180530
一 python简介. 1.创始人: 吉多 .范罗苏姆 \ (Guido van Rossum). 2.时间 : 1989年. 3.主要应用领域 : 云计算 \ WEB开发 \ ...
- python全栈开发 * 27知识点汇总 * 180710
27 time os sys 模块 time 模块 一.表示时间的三种方式 时间戳(timestamp), 元组(struct_time),格式化时间字符串(Format string) 小 ...
- python全栈开发 * 26知识点汇总 * 180709
26 logging collections random 模块 一.logging低配:日志不能写入文件与显示同时进行 import logging logging.basicConfig(leve ...
- python全栈开发* 02 知识点汇总 * 180531
运算符和编码 一 格式化输出 1 .输入 name ,age , job , hobby. 输出 : --------------- info of Mary ------------ ...
- python全栈开发 * 36知识点汇总 * 180721
36 操作系统的发展史 进程一.手工操作--穿孔卡片 1.内容: 程序员将对应于程序和数据的已穿孔的纸带(或卡片)装入输入机,然后启动输入机把程序和数据输入计算机内存,接着通过控制 台开关启动程序针对 ...
- python全栈开发 * 31知识点汇总 * 180716
31 模块和包一.模块(一)模块的种类:内置模块,自定义模块,扩展模块第三方模块(二)自定义模块 1.模块的创建 : 新建一个py文件. 2.模块名 : 模块名需要符合变量的命名规范. 3.模块的导入 ...
随机推荐
- IntelliJ IDEA web项目 工程构建运行部署
- method.invoke(...)反射点
import java.lang.reflect.Method; import java.util.Arrays; /** * @Author: hoobey * @Description: * @D ...
- Spring HttpInvoker 从实战到源码追溯
Spring HttpInvoker 作为 Spring 家族中老牌远程调用模型,深受开发者喜爱. 其主要目的是来执行基于 HTTP 的远程调用(轻松穿越防火墙),并使用标准的 JDK 序列化机制. ...
- iOS - 统计代码行数
终端 -> 进入文件夹 查看每一行的行数 find . -name "*.m" -or -name "*.h" -or -name "*.xib ...
- 中期linux课程考试题
[口头表达] 1)请描述你了解的磁盘分区的相关知识2)什么是rsync,你有什么生产环境的应用?3)在生产环境中,公司的IDC机房即将超过254台机器,请问你有什么解决方案来规划扩展IDC机房的内网网 ...
- OSI(Open System Interconnect) 网络七层协议
你作为用户想发个快递,你叫来了顺丰,顺丰快递员从你手里拿走了快递,又装进一个盒子,然后把一个快递单子贴在了上面. 快递员回到集散中心,将快递往那一扔不管了,分拣员把快递按投递的省市分开,发往同一地区的 ...
- Android Studio 好用的设置
Android Studio 好用的设置 设置目录 Getter 模板修改--自动处理 null 判断 格式化代码自动整理方法位置--广度 or 深度 设置步骤: Getter 模板修改,自动处理 n ...
- springboot2.x接口返回中文乱码
@Configuration public class GlobalConversConfiguration extends WebMvcConfigurationSupport { @Bean pu ...
- 你真的理解Python中MRO算法吗?[转]
[前言] MRO(Method Resolution Order):方法解析顺序.Python语言包含了很多优秀的特性,其中多重继承就是其中之一,但是多重继承会引发很多问题,比如二义性,Python中 ...
- linux下启动和关闭tomcat服务的方式
Linux下tomcat服务的启动.关闭与错误跟踪,通常通过以下几种方式启动关闭tomcat服务: 切换到tomcat主目录下的bin目录 启动tomcat服务 生产模式: 方式一:直接启动 ./st ...