20序列化模块和模块

Posted wyx666

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了20序列化模块和模块相关的知识,希望对你有一定的参考价值。

1、什么是序列化?

  就是转向一个字符串的数据类型

2、为什么序列化?

  1、数据存储(将对象从一个地方传递到另一个地方。)

  2、网络上传输的时侯

  3、以某种存储形式使自定义对象持久化

3、序列化:从数据类型转向字符串的过程

  反序列化:从字符串转向数据的过程

二、jason模块提供的四个功能:domp、load、domps、loads

  dumps和loads

import json
dic = {‘k1‘:‘v1‘,‘k2‘:‘v2‘,‘k3‘:‘v3‘}
str_dic = json.dumps(dic)  #序列化:将一个字典转换成一个字符串
print(type(str_dic),str_dic)  #<class ‘str‘> {"k3": "v3", "k1": "v1", "k2": "v2"}
#注意,json转换完的字符串类型的字典中的字符串是由""表示的

dic2 = json.loads(str_dic)  #反序列化:将一个字符串格式的字典转换成一个字典
#注意,要用json的loads功能处理的字符串类型的字典中的字符串必须由""表示
print(type(dic2),dic2)  #<class ‘dict‘> {‘k1‘: ‘v1‘, ‘k2‘: ‘v2‘, ‘k3‘: ‘v3‘}


list_dic = [1,[‘a‘,‘b‘,‘c‘],3,{‘k1‘:‘v1‘,‘k2‘:‘v2‘}]
str_dic = json.dumps(list_dic) #也可以处理嵌套的数据类型 
print(type(str_dic),str_dic) #<class ‘str‘> [1, ["a", "b", "c"], 3, {"k1": "v1", "k2": "v2"}]
list_dic2 = json.loads(str_dic)
print(type(list_dic2),list_dic2) #<class ‘list‘> [1, [‘a‘, ‘b‘, ‘c‘], 3, {‘k1‘: ‘v1‘, ‘k2‘: ‘v2‘}]

loads和dumps

  

  load和dump

import json
f = open(‘json_file‘,‘w‘)
dic = {‘k1‘:‘v1‘,‘k2‘:‘v2‘,‘k3‘:‘v3‘}
json.dump(dic,f)  #dump方法接收一个文件句柄,直接将字典转换成json字符串写入文件
f.close()

f = open(‘json_file‘)
dic2 = json.load(f)  #load方法接收一个文件句柄,直接将文件中的json字符串转换成数据结构返回
f.close()
print(type(dic2),dic2)

load和dump

2、pickle模块

  1、所有的python中的数据类型都可以转化成字符串形式

  2、pickle序列化的内容只有python能理解

  3、且部分反序列化依赖python代码

3、shelve

  序列化句柄

  使用句柄直接操作,非常方便

 

 

 

模块

1、模块调用的顺序:

 ·所有的模块导入都应该尽量往上写,顺序为:内置模块、扩展模块、自定义模块

2、模块导入的规范:

   import 

   1、import 模块名
     (调用的时候:模块名.变量名, 和本文件中的变量名完全不冲突)
   2、 import 模块名 as 重命名的模块名 : 提高代码的兼容性
   3、 import 模块1,模块2(调用多个模块)

   from import

   1、from 模块名 import 变量名

   直接使用 变量名 就可以完成操作,如果本文件中有相同的变量名会发生冲突
         
   2、from 模块名 import 变量名字 as 重命名变量名
        3、 from 模块名 import 变量名1,变量名2
        4、 from 模块名 import *  (将模块中的所有变量名都放到内存中,如果本文件中有相同的变量名会发生冲突)
   5、from 模块名 import * 和 __all__ 是一对  (没有这个变量,就会导入所有的名字,如果有all 只导入all列表中的名字)

3、模块执行的顺序  

  1、先从sys.modules里查看是否已经被导入(所以模块不会重复被导入)

  2、如果没有导入,就依据sys.path路径去寻找模块(sys.path导入模块)

  3、就到了就导入模块

  4、创建这个模块的命名空间

  5、执行文件,把文件中的名字都放入命名空间里

 

4、在python中自定义的模块中,有的时候对于这个模块的修改需要执行一个自己单独的结果(比如打印一个只在本模块(文件)显示的内容),而在调用的模块就不显示这个单独

  的内容,所以这里有一个需要说明的内容:(写到这里有些奔溃,好像没有人看这个,这些都是我自己写的话)

  __name__(亮相了!!!!!!!)

在模块中 有一个变量__name__,
当我们直接执行这个模块的时候,__name__ == __main__
当我们执行其他模块,在其他模块中引用这个模块的时候,这个模块中的__name__ == 模块的名字

 

  http://www.cnblogs.com/Eva-J/articles/7228075.html#_label9

 

以上是关于20序列化模块和模块的主要内容,如果未能解决你的问题,请参考以下文章

如何使用模块化代码片段中的LeakCanary检测内存泄漏?

如何有条件地将 C 代码片段编译到我的 Perl 模块?

Python之常用模块(re,时间,random,os,sys,序列化模块)(Day20)

python常用模块(模块和包的解释,time模块,sys模块,random模块,os模块,json和pickle序列化模块)

2016/09/20

Part5-1-2 Nodejs 核心模块