一. 包

  一个含有__init__.py 文件的文件夹(将py 文件中的内容划分成不同的部分放在不同的py 文件中,在将这些py 文件放在一个文件夹中)

  是模块,不做执行文件,仅做调用

m1.py  和  m2.py  和__init__.py 同层级(同在aaa文件夹下)
run.py 执行文件 与aaa文件夹同层级(执行文件要调用aaa文件夹里面m1.py 和m2.py 中的变量) m1.py 文件中:
def func1():
print('func1函数') m2.py 文件中
def func2():
print('func2函数') __init__.py 文件中: from aaa.m1 import func1
from aaa.m2 import func2 run.py 文件中调用:
import aaa
aaa.func1()
aaa.func2() 总结: 在run.py 文件中import aaa 时先产生了名称空间,然后自动运行aaa文件夹下的 __init__.py 文件, 此时__init__.py 文件中已经导入了fu
nc1 和 func2 函数, 因此在run.py 文件中可以直接调用func1 和 func2函数

__init__.py 文件中绝对导入: 从包的顶级目录(aaa)开始查找

__init__.py 文件中相对导入:只能在包内使用,仅限于包内模块彼此相互引用,用点 . 代替(当前)文件夹名

             例: from .m1 import func1          from ..m3 import fff    一个点代表一级目录

二. json 与 pickle模块: 解决序列化问题

  序列化: 将内存中的数据类型转成另一种格式

    例如:字典====》其他格式======》存在硬盘

  反序列化: 将硬盘中的其他格式转回python java 等能识别的格式

   例如: 硬盘中的其他格式====》读取其他格式=====》 转换回字典类型

  序列化原因: 持久保存程序的运行状态

         数据的跨平台应用

  如何序列化: json 和 pickle

    json格式             python格式

    {}                          dict

    []        list              ==========》json 优点:是一种通用格式,所有编程语言都能识别(跨平台性好)

    1233       int  float      ==========》json  缺点:不能识别所有的python类型(不能识别集合类型)

    true/false             True/False       

    null                       None

   pickle 优点:能识别所有的python类型

   pickle 缺点: 只能被python这门编程语言识别(无法跨平台交互)

例: 用json 将字典序列化存入内存

d={'name':'egon','password':}

d_json=json.dumps(d)
with open('r.txt','wt','utf-8') as f:
f.write(d_json) 方法二: 使用 dump()
with open('r.txt','wb') as f: ==============》 json 用途:持久保存程序的运行状态 和 数据的跨平台交互
json.dump(d,f) # 将硬盘中的 json 格式转换为python中的字典 with open('r.txt','rt') as f:
dic_json=f.read()
dic=json.loads(dic_json) 方法二:
with open('r.txt','rt') as f:
d= json.load(f)
用pickle将字典序列化成其他格式存入硬盘,然后将硬盘中的内容读出,然后将其再转换为python中的字典格式
d={'name':'egon','password':123}

d_pickle=pickle.dumps(d)
with open('r.txt','wb') as f: # 只能用b模式
  f.write(d_pickle) 方法二: dump()
with open('r.txt','wb') as f: =========> pickle 唯一用途将数据存入硬盘
  pickle.dump(d,f)
然后将其再转换为python中的字典格式
with open('r.txt','rb') as f:
d_pickle=f.read()
d=pickle.loads(d_pickle) 方法二:
with open('r.txt','rb')
d=pickle.load(f)

包--json 与 pickle 模块的更多相关文章

  1. python-时间模块,random、os、sys、shutil、json和pickle模块

    一.time与datetime模块 time模块: 时间戳:表示的是从1970年1月1日00:00:00开始按秒计算的偏移量,返回类型为float类型 格式化时间字符串(Format String) ...

  2. python模块(json和pickle模块)

    json和pickle模块,两个都是用于序列化的模块 • json模块,用于字符串与python数据类型之间的转换 • pickle模块,用于python特有类型与python数据类型之间的转换 两个 ...

  3. Python json和pickle模块

    用于序列化的两个模块 json,用于字符串 和 python数据类型间进行转换 pickle,用于python特有的类型 和 python的数据类型间进行转换 Json模块提供了四个功能:dumps. ...

  4. Python之时间模块、random模块、json与pickle模块

    一.时间模块 1.常用时间模块 import time # 时间分为三种格式 #1.时间戳---------------------以秒计算 # start= time.time() # time.s ...

  5. python常用模块之json、pickle模块

    python常用模块之json.pickle模块 什么是序列化? 序列化就是把内存里的数据类型转换成字符,以便其能存储到硬盘或者通过网络进行传输,因为硬盘或网络传输时只接受bytes. 为什么要序列化 ...

  6. os模块,sys模块,json和pickle模块,logging模块

    目录 OS模块 sys模块 json和pickle模块 序列化和反序列化 json模块 pickle logging模块 OS模块 能与操作系统交互,控制文件 / 文件夹 # 创建文件夹 import ...

  7. 模块讲解---os模块,sys模块,json和pickle模块,logging模块

    目录 模块的用法 os模块 常用的功能 sys模块 常用的功能 json和pickle模块 4. logging模块 模块的用法 通过 import 或者from......import...... ...

  8. 第十章、json和pickle模块

    目录 第十章.json和pickle模块 一.序列化 二.json 三.pickle模块 第十章.json和pickle模块 一.序列化 把对象(变量)从内存中变成可存储或传输的过程称之为序列化, 序 ...

  9. python(6)- json和pickle模块

    这是用于序列化的两个模块: json: 用于字符串和python数据类型间进行转换 pickle: 用于python特有的类型和python的数据类型间进行转换 Json模块提供了四个功能:dumps ...

随机推荐

  1. Spring官网下载各版本jar包

    1:浏览器输入官网地址:http://spring.io/projects 2:点击如图树叶页面按钮.  3:点击如图小猫图片按钮.  4:查找downloading spring artifacts ...

  2. 关于Java类和包的那些事

    *.Java文件 问题:一个.java源文件中是否可以包括多个类(不是内部类)?有什么限制? 答案:可以有多个类,但只能有一个public的类,并且public的类名必须与文件名相一致.一个文件中可以 ...

  3. 牛客网NOIP赛前集训营-提高组(第一场)A 中位数

    中位数 思路: 二分答案 代码: #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize(4) #include< ...

  4. (转)C# Where关键词的用法

    where(泛型类型约束) where关键词一个最重要的用法就是在泛型的声明.定义中做出约束. 约束又分为接口约束.基类约束.构造函数约束.函数方法的约束,我们慢慢介绍. 接口约束 顾名思义,泛型参数 ...

  5. v891 安卓平板的root

    看了 油管的视频,标题:Onda V891 - Root Android 4.4.4 (Kit Kat) 2)下载工具,照着做就行了. 3)root完之后,安装 [钛备份](TitaniumBacku ...

  6. 雷林鹏分享:C# 变量

    C# 变量 一个变量只不过是一个供程序操作的存储区的名字.在 C# 中,每个变量都有一个特定的类型,类型决定了变量的内存大小和布局.范围内的值可以存储在内存中,可以对变量进行一系列操作. 我们已经讨论 ...

  7. Onsen UI快速入门 --Onsen UI

     一.什么是Onsen UI? 1.一系列专为移动应用程序设计的丰富UI组件.具有遵循原生iOS和Android设计标准的即时实现功能.免费使用,100%开源软件(Apache v2许可证).Onse ...

  8. scrapy 爬虫框架之持久化存储

    scrapy  持久化存储 一.主要过程: 以爬取校花网为例 : http://www.xiaohuar.com/hua/ 1.  spider    回调函数     返回item 时    要用y ...

  9. 使用xshell远程连接

    xshell 是一个强大的安全终端模拟软件,它支持SSH1,SSH2以及microsoft windows 平台的TELNET协议.xshell通过互联网到远程主机的安全连接. xshell可以在wi ...

  10. HTML页面的三种弹框方式

    1.弹出警告框,带确定按钮:alert 2.弹出,选择框 有确认和取消按钮 confirm 3. 弹出,输入框 : prompt