Python 基础 - Day 4 Learning Note - 模块 - Json & Pickle

Json和Pickle的区别

在python的序列化的两个模块中,json模块是用于字符串和python数据类型间进行转换;另一个pickle模块,是用于python特有的类型(所有数据类型和python的数据类型间进行转换。json是可以在不同语言之间交换数据的,而pickle只在python之间使用。json只能序列化最基本的数据类型,json只能把常用的数据类型序列化(列表、字典、列表、字符串、数字、),比如日期格式、类对象!josn就不行了。而pickle可以序列化所有的数据类型,包括类,函数都可以序列化。

但是,两者的常用操作都一样,包括:dumps, loads, dump, load

JSON

介绍

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言 (正逐渐替代xml文件作为交换文件)。Json文件易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。JSON在python中分别由list和dict组成。python类型数据和JSON数据格式互相转换如下:

JSON的常用操作

1. json.dumps把 python数据类型 转换成 Json字符串

import json

# example 1: 将python数据类型(e.g. 字典)转为 json 字符串
data1 = {
    ‘no‘: 1,
    ‘name‘: ‘Runoob‘,
    ‘utl‘: ‘http://www.runoob.com‘
}

data1_json = json.dumps(data1)
print(‘Python原始数据: ‘,data1)
print(type(data1))
print(‘JSON对象:‘,data1_json)
print(type(data1_json))

返回值:
Python原始数据:  {‘no‘: 1, ‘name‘: ‘Runoob‘, ‘utl‘: ‘http://www.runoob.com‘}
<class ‘dict‘>
JSON对象: {"no": 1, "name": "Runoob", "utl": "http://www.runoob.com"}
<class ‘str‘>

2. json.loads 把字符串转换成数据类型

# example 2: 将 JSON 对象(e.g.字符串)转为 python 数据类型(e.g. 字典)
data2 = json.loads(data1_json)
print(‘data2[name]:‘, data2[‘name‘])
print(‘data2[utl]: ‘, data2[‘utl‘])

返回值:
data2[name]: Runoob
data2[utl]:  http://www.runoob.com

3.  dump把python数据类型转换成json字符串并存储在文件中;

# example 3: 写入json文件存储
with open(‘test_write.json‘,‘a‘) as f:
    json.dump(data1_json, f)

json文件 test_write.json 中写入:

"{\"no\": 1, \"name\": \"Runoob\", \"utl\": \"http://www.runoob.com\"}"

4. load把文件打开从json字符串转换成python数据类型

# example 4: 读出json文件并转为python 数据类型
with open(‘test.json‘,‘r‘) as f1:
    data3 =json.load(f1)
    print(data3)
    print(type(data3))   

返回值:

[‘foo‘, {‘bar‘: [‘baz‘, None, 1.0, 2]}]
<class ‘list‘>

Pickle

Pickle有自己的一套语言,只可以在python中使用,将任意一个Python对象转换成一系统字节的这个操作过程,不是加密(串行化对象)。pickle反序列化后的对象与原对象是等值的副本对象,类似与deepcopy。也可以说,序列化的不是内存地址,而是整个程序对象。常用操作和json一样。主要的作用是函数和类的序列化并存读。

#!usr/bin/env python
# -*- coding:utf-8 -*-

import pickle

info = [1,2,3,‘abc‘,‘iplaypython‘]
print(‘原始数据:‘,info)

data1 = pickle.dumps(info)
print("序列化:",data1)

data2 = pickle.loads(data1)
print("反序列化:",data2)

Pickle的序列化和反序列化操作

Reference:

Python3  Json

http://www.runoob.com/python3/python3-json.html

Python进阶 -- 4. 处理json文件

http://blog.csdn.net/lwbeyond/article/details/61198555

python读写json文件的简单实现

http://www.jb51.net/article/110899.htm

时间: 2024-12-24 06:55:32

Python 基础 - Day 4 Learning Note - 模块 - Json & Pickle的相关文章

Python 基础 - Day 5 Learning Note - 模块 之 标准库:random 模块

常用操作 import random # 随机浮点数 print(random.random()) # 0.1706000097536472 # 返回生成一个0到1的随机浮点数: 0<= n <= 1 print(random.uniform(1,8)) # 4.060336609768256 # 函数语法: random.uniform(a,b) # 返回生成以a为下限,b为上限的随机浮点数: a<=n<=b # 随机整数 print(random.randint(1,10))

Python 基础 - Day 5 Learning Note - 模块 之 介绍篇

定义 模块(module)支持从逻辑上组织Python代码,本质就是.py结尾的python文件(e.g.文件名:test.py; 模块名:test),目的是实现某项功能.将其他模块属性附加到你的模块中的操作叫导入(import). 模块分为三类:标准库.开源模块(open source module)和自定义模块. 包(package)是一个有层次的文件目录结构, 定义了一个由模块和子包组成的python应用程序执行环境.和模块及类一样,也使用句点属性标识来访问他们的元素.使用标准的impor

Python 基础 - Day 5 Learning Note - 模块 之 标准库:xml (9)

xml 模块介绍 和json一样,适用于不同语言及程序的数据交换的协议.但是json用起来更简单,并有代替xml的趋势. 现在多数金融数据提供方(e.g. bloombegy)还在用xml的方式. 在python中,生成和解析 XML 文件 用 导入 xml.etree.ElementTree 模块 xml文件的格式 xml的格式如下,就是通过<>节点来区别数据结构的: xml的格式 常用操作 读取xml import xml.etree.ElementTree as ET tree = ET

Python 基础 - Day 5 Learning Note - 模块 之 标准库:RE (14) 正则表达式

RE 模块介绍 正则表达式(RE)用作于处理文件和数据,为高级文本模式匹配,以及搜索-替代等功能提供基础. 实质就是一些由字符和特殊符号(元字符:metacharacter)组成的字符串,它们描述了这些字符和字符的某种重复方式,因此能按某种模式匹配一个有相似特征的字符串的集合,也能按某种模式匹配一系列有相似特征的字符串,我们称为模式匹配 (patten match). 在python中, pattern-match 有两种主要方式完成: 搜索(search)和匹配(match). 搜索,在字符串

Python 基础 - Day 5 Learning Note - 模块 之 标准库:datetime (2)

介绍 Datetime 模块是time模块的再次封装,提供了更多的接口.主要是日期和时间的解析,格式化及运算. 其他关于时间的模块: time - basic calendar - basic pytz - 关于time zones dateutil - extension of datetime 常用操作 Times类 import datetime t = datetime.time(1,2,3) # 01:02:03 print(t) # 语法: datetime.time(hour,mi

Python 基础 - Day 5 Learning Note - 模块 之 标准库:ConfigParser (10)

configparser模块介绍 用于生成和修改常见的配置文档(configuration file), 配置文件格式 用户配置文件就是在用户登录电脑时,或是用户在使用软件时,软件系统为用户所要加载所需环境的设置和文件的集合.它包括所有用户专用的配置设置,如程序项目.屏幕颜色.网络连接.打印机连接.鼠标设置及窗口的大小和位置等.一般格式包括ini,cfg,xml, config等. 配置文件的格式如下 [DEFAULT] ServerAliveInterval = 45 Compression

Python 基础 - Day 5 Learning Note - 模块 之 标准库:time (1)

时间的表示方式 1. 间戳 timestamp:  从1970年1月1日 00:00:00 开始按秒计算的偏移量,以float数据类型呈现. 返回时间戳的函数有: time() , clock() 等. 2. sruct_time 元祖方式: 返回struct_time元祖的函数包括 gmtime(), localtime(), strptim(). 返回的元祖包括以下9个元素. 索引 INDEX 属性 ATTRIBUTE 值 VALUES 0 tm_year  比如2011 1 tm_mon

Python 基础 - Day 4 Learning Note - Generator 生成器

列表生成器/列表解析 list comprehension 简单灵活地创建列表,通常和lambda(), map(), filter() 一起使用 通过列表生成式, 直接创建列表.但是,收到内容限制,列表容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问几个元素,那其他的就白占空间.列表生成器能够一边循环一边计算,大大节省大量的空间.是生成器的一种. 只有调用,才能生成. 不支持切片操作,只能通过__next()___一个个取数字. 基本语法

Python 基础 - Day 4 Learning Note - Decorator 装饰器

装饰器的知识准备 函数,函数参数 作用域: 全局变量,局部变量 变量解析规则:LEGB法则 - 假设嵌套函数(第二层函数),解析器查找内部函数的变量的顺序如下. 在任何一层先找到了符合要求的变量,则不再向外查找.如果没有,则抛出N Local - 本地函数内部,通过任何方式赋值的,而且没有被global关键字声明为全局变量的变量 Enclosing - 直接该内部函数的外围空间(即它的上层函数)的本地作用域.多层嵌套,则有内而外逐层查找,直至最外层的函数 Global - 全局空间(模块encl