1. 概述

JSON (JavaScript Object Notation)是一种使用广泛的轻量数据格式. Python标准库中的json模块提供了JSON数据的处理功能.

Python中一种非常常用的基本数据结构就是字典(Dictionary). 它的典型结构如下:

  1. d = {
  2. 'a': 123,
  3. 'b': {
  4. 'x': ['A', 'B', 'C']
  5. }
  6. }

而JSON的结构如下:

  1. {
  2. "a": 123,
  3. "b": {
  4. "x": ["A", "B", "C"]
  5. }
  6. }

可以看到, Dictionary和JSON非常接近, 而Python中的json库提供的主要功能, 也是两者之间的转换.

2. 读取JSON

json.loads方法可以将包含了一个JSON数据的str, bytes或者bytearray对象, 转化为一个Python Dictionary. 它的完型接口签名如下:

  1. json.loads(s, *, encoding=None, cls=None, object_hook=None, parse_float=None, parse_int=None, parse_constant=None, object_pairs_hook=None, **kw)

2.1 最简单的例子

json.loads最基本的使用方式就是将一个包含JSON数据的str传递给这个方法:

  1. >>> json.loads('{"a": 123}')
  2. {'a': 123}

注意

在Python中, str值可以放在一对单引号中, 也可以放在一对双引号中:

  1. >>> 'ABC' == "ABC"
  2. True

所以, 在定义Dictionary的str类型的键和值的时候, 使用单引号或者双引号都是合法和等价的:

  1. >>> {"a": 'ABC'} == {'a': "ABC"}
  2. True

但是, 在JSON中, 字符串数据只能放在双引号中, 因而json.loads方法处理的字符串的JSON内容中, 字符串必须使用双引号. 否则就会发生解码错误:

  1. >>> json.loads("{'a': 123}")
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/__init__.py", line 354, in loads
  5. return _default_decoder.decode(s)
  6. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/decoder.py", line 339, in decode
  7. obj, end = self.raw_decode(s, idx=_w(s, 0).end())
  8. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/decoder.py", line 355, in raw_decode
  9. obj, end = self.scan_once(s, idx)
  10. json.decoder.JSONDecodeError: Expecting property name enclosed in double quotes: line 1 column 2 (char 1)

如果被处理的Python字符串是包含在双引号中的, 那么JSON中的双引号就需要转义:

  1. >>> json.loads("{\"a\": 123}")
  2. {'a': 123}

2.2 bytesbytearray数据

对于内容是JSON数据的bytesbytearray, json.loads方法也可以处理:

  1. >>> json.loads('{"a": 123}'.encode('UTF-8'))
  2. {'a': 123}
  3. >>> json.loads(bytearray('{"a": 123}', 'UTF-8'))
  4. {'a': 123}

2.3 编码格式

json.loads的第二个参数是encoding没有实际作用.

由于Python 3中str类型总是使用UTF-8编码, 所以s参数为str类型时, json.loads方法自动使用UTF-8编码. 并且, str不能以BOM字节开头.

s参数为bytes或者bytearray时, json.loads方法会自动判断为UTF-8, UTF-16还是UTF-32编码. 默认也是将其按照UTF-8编码转化为str对象进行后续处理.

2.4 数据类型转换

JSON可以表示四种主类型数据

  1. 字符串 string

  2. 数字 number

  3. 布尔类 boolean

  4. 空值 null

以及两结数据结构

  1. 对象 object

  2. 数组 array

默认实现中, JSON和Python之间的数据转换对应关系如下表:

JSON Python
object dict
array list
string str
number (int) int
number (real) float
true True
false False
null None

实际转换情况如下例:

  1. >>> json.loads("""
  2. ... {
  3. ... "obj": {
  4. ... "str": "ABC",
  5. ... "int": 123,
  6. ... "float": -321.89,
  7. ... "bool_true": true,
  8. ... "bool_false": false,
  9. ... "null": null,
  10. ... "array": [1, 2, 3]
  11. ... }
  12. ... }""")
  13. {'obj': {'str': 'ABC', 'int': 123, 'float': -321.89, 'bool_true': True, 'bool_false': False, 'null': None, 'array': [1, 2, 3]}}

对于JSON中数字number类型的数据, 有以下几点需要注意:

  1. JSON中的实数real number类型的精度不能超过Python中的float类型的精度范围, 否则就有精度损失. 如下例:

    1. >>> json.loads('3.141592653589793238462643383279')
    2. 3.141592653589793
  2. JSON标准不包括非数字NaN, 正无穷Infinity和负无穷-Infinity, 但是json.loads方法默认会将JSON字符串中的NaN, Infinity, -Infinity转化为Python中的float('nan'), float('inf')float('-inf'). 注意, 这里JSON中的NaN, Infinity, -Infinity必须大小写正确并且拼写完整. 如下例

    1. >>> json.loads('{"inf": Infinity, "nan": NaN, "ninf": -Infinity}')
    2. {'inf': inf, 'nan': nan, 'ninf': -inf}

2.5 自定义JSON对象转换类型

json.loads默认将JSON中的对象数据转化为Dictionary类型, object_hook参数可以用来改变构造出的对象.

object_hook接受一个函数, 这个函数的输入参数为JSON中对象数据转化出的Dictionary对象, 其返回值则为自定义的对象. 如下例所示:

  1. >>> class MyJSONObj:
  2. ... def __init__(self, x):
  3. ... self.x = x
  4. ...
  5. >>> def my_json_obj_hook(data):
  6. ... print('obj_hook data: %s' % data)
  7. ... return MyJSONObj(data['x'])
  8. ...
  9. >>> result = json.loads('{"x": 123}', object_hook=my_json_obj_hook)
  10. obj_hook data: {'x': 123}
  11. >>> type(result)
  12. <class '__main__.MyJSONObj'>
  13. >>> result.x
  14. 123

当JSON中的对象有嵌套时, json.loads方法会按照深度优先的方式遍历对象树, 将各层的对象数据传递给object_hook. 叶节点的JSON对象构造出的Python对象, 会作为父节点的一个值, 传递给父节点的object_hook方法. 如下例:

  1. >>> class MyJSONObj:
  2. ... def __init__(self, x, y):
  3. ... self.x = x
  4. ... self.y = y
  5. ...
  6. >>> def my_json_obj_hook(data):
  7. ... print('obj_hook data: %s' % data)
  8. ... return MyJSONObj(**data)
  9. ...
  10. >>> result = json.loads('{"x": {"x": 11, "y": 12}, "y": {"x": 21, "y":22}}', object_hook=my_json_obj_hook)
  11. obj_hook data: {'x': 11, 'y': 12}
  12. obj_hook data: {'x': 21, 'y': 22}
  13. obj_hook data: {'x': <__main__.MyJSONObj object at 0x10417ef28>, 'y': <__main__.MyJSONObj object at 0x10417ed68>}

除了object_hook参数以外, 还有一个object_pairs_hook参数. 这个参数同样可以用来改变json.loads方法构造出的Python对象的类型. 这个参数和object_hook的不同, 在于传入的方法所接收到的输入数据不是一个Dictionary, 而是一个包含tuplelist. 每个tuple都有两个元素, 第一个元素是JSON数据中的键, 第二个元素是这个键对应的值. 如JSON对象

  1. {
  2. "a": 123,
  3. "b": "ABC"
  4. }

对应的输入数据是

  1. [
  2. ('a': 123),
  3. ('b', 'ABC')
  4. ]

当调用json.loads方法时, 同时指定object_hookobject_pairs_hook, object_pairs_hook会覆盖object_hook参数.

2.6 自定义JSON数字转换类型

默认实现中, JSON中的实数被转换为Python的float类型, 整数被转换为int或者long类型. 类似object_hook, 我们可以通过parse_floatparse_int参数指定自定义的转换逻辑. 这两个方法的输入参数为表示JSON实数或者整数的字符串. 下例中, 我们将实数转换为numpy.float64, 将整数转换为numpy.int64:

  1. >>> def my_parse_float(f):
  2. ... print('%s(%s)' % (type(f), f))
  3. ... return numpy.float64(f)
  4. ...
  5. >>> def my_parse_int(i):
  6. ... print('%s(%s)' % (type(i), i))
  7. ... return numpy.int64(i)
  8. ...
  9. >>> result = json.loads('{"i": 123, "f": 321.45}', parse_float=my_parse_float, parse_int=my_parse_int)
  10. <type 'str'>(123)
  11. <type 'str'>(321.45)
  12. >>> type(result['i'])
  13. <type 'numpy.int64'>
  14. >>> type(result['f'])
  15. <type 'numpy.float64'>

2.6.1 自定义NaN, Infinity-Infinity转换类型

由于标准JSON数据不支持NaN, Infinity-Infinity, 所以parse_float并不会接收到这几个值. 当需要自定义这几个值转换的对象的时候, 就需要使用另外一个接口parse_constant. 比如下例中, 将这几个值同样转换为numpy.float64类型:

  1. >>> def my_parse_constant(data):
  2. ... print('%s(%s)' % (type(data), data))
  3. ... return numpy.float64(data)
  4. ...
  5. >>> result = json.loads('{"inf": Infinity, "nan": NaN, "ninf": -Infinity}', parse_constant=my_parse_constant)
  6. <type 'str'>(Infinity)
  7. <type 'str'>(NaN)
  8. <type 'str'>(-Infinity)
  9. >>> result['inf']
  10. inf
  11. >>> type(result['inf'])
  12. <type 'numpy.float64'>

2.7 非对象顶级值

根据JSON规范, 一个JSON数据中, 可以只包含一个值, 而不是一个完整的对象. 这个值可以是一个字符串, 一个数字, 布尔值, 空值, 或者一个数组. 除了这三种JSON规范中给出的类型, 还可以是NaN, Infinity或者-Infinity:

  1. >>> json.loads('"hello"')
  2. 'hello'
  3. >>> json.loads('123')
  4. 123
  5. >>> json.loads('123.34')
  6. 123.34
  7. >>> json.loads('true')
  8. True
  9. >>> json.loads('false')
  10. False
  11. >>> print(json.loads('null'))
  12. None
  13. >>> json.loads('[1, 2, 3]')
  14. [1, 2, 3]

2.8 重复键名

在同一层级JSON对象中, 不应当出现重复的键名, 不过JSON规范中没有给出这种情况的处理标准. 在json.loads中, 当JSON数据中有重复键名, 则后面的键值会覆盖前面的:

  1. >>> json.loads('{"a": 123, "b": "ABC", "a": 321}')
  2. {'a': 321, 'b': 'ABC'}

2.9 处理JSON数据文件

当JSON数据是保存在一个文件中的时候, json.load方法可以用来从这个文件中读取数据, 并转换为Python对象. json.load方法的第一个参数就是指向JSON数据文件的文件类型对象.

比如/tmp/data.json文件的内含如下:

  1. {
  2. "a": 123,
  3. "b": "ABC"
  4. }

可以使用下例中的代码来读取并转化文件中的JSON数据:

  1. >>> with open('/tmp/data.json') as jf:
  2. ... json.load(jf)
  3. ...
  4. {u'a': 123, u'b': u'ABC'}

除了文件类型的对象, 只要是实现了read方法的类文件对象, 都可以作为fp参数, 比如下例中的io.StringIO:

  1. >>> sio = io.StringIO('{"a": 123}')
  2. >>> json.load(sio)
  3. {'a': 123}

json.load方法的其他参数的意义和使用方法和上文中的json.loads相同, 这里不再赘述.

3 生成JSON

json.dumps方法可以将Python对象转换为一个表示JONS数据的字符串. 它的完整接口签名如下:

  1. json.dumps(obj, *, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, default=None, sort_keys=False, **kw)

它的第一个参数obj即为要转换的数据对象.

  1. >>> json.dumps({'a': 123, 'b': 'ABC'})
  2. '{"a": 123, "b": "ABC"}'

3.1 编码格式

json.dumpsensure_ascii参数用来控制生成的JSON字符串的编码. 其默认值为True, 此时, 所有的非ASCII码字条都会转义. 如果不希望自动进行转义, 则会保持原有编码, 限UTF-8. 如下例所示:

  1. >>> json.dumps({'数字': 123, '字符': '一二三'})
  2. '{"\\u6570\\u5b57": 123, "\\u5b57\\u7b26": "\\u4e00\\u4e8c\\u4e09"}'
  3. >>> json.dumps({'数字': 123, '字符': '一二三'}, ensure_ascii=False)
  4. '{"数字": 123, "字符": "一二三"}'

3.2 数据类型转换

在默认实现中, json.dumps可以处理的Python对象, 及其所有的属性值, 类型必须为dict, list, tuple, str, float或者int. 这些类型与JSON的数据转换关系如下表:

Python JSON
dict object
list, tuple array
str string
int, float, int-&float-derived emuns number
True true
False false
None null

实际转换情况如下示例:

  1. >>> json.dumps(
  2. ... {
  3. ... 'str': 'ABC',
  4. ... 'int': 123,
  5. ... 'float': 321.45,
  6. ... 'bool_true': True,
  7. ... 'bool_false': False,
  8. ... 'none': None,
  9. ... 'list': [1, 2, 3],
  10. ... 'tuple': [12, 34]
  11. ... }
  12. ... )
  13. '{"str": "ABC", "int": 123, "float": 321.45, "bool_true": true, "bool_flase": false, "none": null, "list": [1, 2, 3], "tuple": [12, 34]}'

虽然JSON标准规范不支持NaN, Infinity-Infinity, 但是json.dumps的默认实现会将float('nan'), float('inf')float('-inf')转换为常量NaN, Infinity, 和-Infinity. 如下例所示:

  1. >>> json.dumps(
  2. ... {
  3. ... 'nan': float('nan'),
  4. ... 'inf': float('inf'),
  5. ... '-inf': float('-inf')
  6. ... }
  7. ... )
  8. '{"nan": NaN, "inf": Infinity, "-inf": -Infinity}'

由于这些常量可能会导致生成的JSON字符串不能被其他的JSON实现处理, 为了防止这种情况出现, 可以将json.dumpsallow_nan参数设置为True. 此时, 当处理的Python对象中出现这些值时, json.dumps方法会抛出异常.

3.3 循环引用

json.dumps方法会检查Python对象中是否有循环引用, 如果发现了循环引用, 就会抛出异常. 如下例所示:

  1. >>> circular_obj = {}
  2. >>> circular_obj['self'] = circular_obj
  3. >>> circular_obj
  4. {'self': {...}}
  5. >>> json.dumps(circular_obj)
  6. Traceback (most recent call last):
  7. File "<stdin>", line 1, in <module>
  8. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/__init__.py", line 231, in dumps
  9. return _default_encoder.encode(obj)
  10. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/encoder.py", line 199, in encode
  11. chunks = self.iterencode(o, _one_shot=True)
  12. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/encoder.py", line 257, in iterencode
  13. return _iterencode(o, 0)
  14. ValueError: Circular reference detected

如果不希望json.dumps方法检查循环引用, 可以将参数check_circular设置为False. 但如果此时Python对象中有循环引用, 有可能发生递归嵌套过深的错误或者其他错误, 这么做是比较危险的. 如下例所示:

  1. >>> json.dumps(circular_obj, check_circular=False)
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/__init__.py", line 238, in dumps
  5. **kw).encode(obj)
  6. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/encoder.py", line 199, in encode
  7. chunks = self.iterencode(o, _one_shot=True)
  8. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/encoder.py", line 257, in iterencode
  9. return _iterencode(o, 0)
  10. RecursionError: maximum recursion depth exceeded while encoding a JSON object

3.4 JSON字符串输出格式

json.dumps方法的indent参数可以用来控制JSON字符串的换行和缩进效果.

indent参数默认值为None. 此时, JSON字符串不会有换行和缩进效果. 如下示:

  1. >>> print(json.dumps({'a': 123, 'b': {'x': 321, 'y': 'ABC'}}))
  2. {"a": 123, "b": {"x": 321, "y": "ABC"}}

indent为0或者负数时, JSON字符会包含换行:

  1. >>> print(json.dumps({'a': 123, 'b': {'x': 321, 'y': 'ABC'}}, indent=-1))
  2. {
  3. "a": 123,
  4. "b": {
  5. "x": 321,
  6. "y": "ABC"
  7. }
  8. }
  9. >>> print(json.dumps({'a': 123, 'b': {'x': 321, 'y': 'ABC'}}, indent=0))
  10. {
  11. "a": 123,
  12. "b": {
  13. "x": 321,
  14. "y": "ABC"
  15. }
  16. }

而当indent为正整数时, 除了换行, JSON还会以指定数量的空格为单位在对象层次间进行缩进:

  1. >>> print(json.dumps({'a': 123, 'b': {'x': 321, 'y': 'ABC'}}, indent=2))
  2. {
  3. "a": 123,
  4. "b": {
  5. "x": 321,
  6. "y": "ABC"
  7. }
  8. }

indent还可以是str, 此时, JSON会以str内容为单位进行缩进, 比如制表符\t:

  1. >>> print(json.dumps({'a': 123, 'b': {'x': 321, 'y': 'ABC'}}, indent='\t'))
  2. {
  3. "a": 123,
  4. "b": {
  5. "x": 321,
  6. "y": "ABC"
  7. }
  8. }

json.dumps的另外一个参数separators可以用来设置输出的分隔符. 这个参数的值应当是一个有两个元素的tuple. 其第一个值为成员间的分隔符, 第二个值为键值之间的分隔符. 其默认值也会随上文中的indent参数影响. 当indentNone时, separators的默认值为(', ', ': '), 即分隔符后都有一个空格. 当indent不为None时, 其默认值则为(',', ':'), 即只有键值间分隔符后会有一个空格, 而元素间分隔符则不带空格, 因为此时会有换行.

separators参数的一种可能的使用场景是希望移除所有的非必要格式字符, 以此来减小JSON字符串的大小. 此时可以将separator设置为(',', ';'), 并不设置indent参数, 或者将其显式设置为None:

  1. >>> print(json.dumps({'a': 123, 'b': {'x': 321, 'y': 'ABC'}}, indent=None, separators=(',', ':')))
  2. {"a":123,"b":{"x":321,"y":"ABC"}}

3.5 转换自定义Python对象

json.dumps的默认实现只能转换Dictionary类型的对象. 如果想要转换自定义对象, 需要使用default参数. 这个参数接收一个函数, 这个函数的参数是一个要转换的Python对象, 返回值是能够表示这个Python对象的Dictionary对象. default函数会从对象引用树的顶层开始, 逐层遍历整个对象引用树. 因此, 不用自己实现对象树的遍历逻辑, 只需要处理当前层次的对象. 如下例所示:

  1. >>> class MyClass:
  2. ... def __init__(self, x, y):
  3. ... self.x = x
  4. ... self.y = y
  5. ...
  6. >>> def my_default(o):
  7. ... if isinstance(o, MyClass):
  8. ... print('%s.y: %s' % (type(o), o.y))
  9. ... return {'x': o.x, 'y': o.y}
  10. ... print(o)
  11. ... return o
  12. ...
  13. >>> obj = MyClass(x=MyClass(x=1, y=2), y=11)
  14. >>> json.dumps(obj, default=my_default)
  15. <class '__main__.MyClass'>.y: 11
  16. <class '__main__.MyClass'>.y: 2
  17. '{"x": {"x": 1, "y": 2}, "y": 11}'

3.6 非字符串类型键名

在Python中, 只是可哈希(hashable)的对象和数据都可以做为Dictionary对象的键, 而JSON规范中则只能使用字符串做为键名. 所以在json.dumps的实现中, 对这个规则进行了检查, 不过键名允许的范围有所扩大, str, int, float, boolNone类型的数据都可以做为键名. 不过当键名非str的情况时, 键名会转换为对应的str值. 如下例:

  1. >>> json.dumps(
  2. ... {
  3. ... 'str': 'str',
  4. ... 123: 123,
  5. ... 321.54: 321.54,
  6. ... True: True,
  7. ... False: False,
  8. ... None: None
  9. ... }
  10. ... )
  11. '{"str": "str", "123": 123, "321.54": 321.54, "true": true, "false": false, "null": null}'

而当出现其他类型的键名时, 默认出抛出异常:

  1. >>> json.dumps({(1,2): 123})
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/__init__.py", line 231, in dumps
  5. return _default_encoder.encode(obj)
  6. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/encoder.py", line 199, in encode
  7. chunks = self.iterencode(o, _one_shot=True)
  8. File "/Library/Frameworks/Python.framework/Versions/3.6/lib/python3.6/json/encoder.py", line 257, in iterencode
  9. return _iterencode(o, 0)
  10. TypeError: keys must be a string

json.dumpsskipkeys参数可以改变这个行为. 当将skipkeys设置为True时, 遇到非法的键名类型, 不会抛出异常, 而是跳过这个键名:

  1. >>> json.dumps({(1,2): 123}, skipkeys=True)
  2. '{}'

3.7 生成JSON文件

当需要将生成的JSON数据保存到文件时, 可以使用json.dump方法. 这个方法比json.dumps多了一个参数fp, 这个参数就是用来保存JSON数据的文件对象. 比如, 下例中的代码

  1. >>> with open('/tmp/data.json', mode='a') as jf:
  2. ... json.dump({'a': 123}, jf)
  3. ...

就会将JSON数据写入到/tmp/data.json文件里. 代码执行完后, 文件内容为

  1. {"a": 123}

json.dump方法也可以接受其他类文件对象:

  1. >>> sio = io.StringIO()
  2. >>> json.dump({'a': 123}, sio)
  3. >>> sio.getvalue()
  4. '{"a": 123}'

json.dump的其他参数和json.dumps的用法相同, 这里不再赘述.

4 SON解码和编码类实现

json.loads, json.load, json.dumpsjson.dump这四个方法是通过json.JSONDecoderjson.JSONEncoder这两个类来完成各自的任务的. 所以也可以直接使用这两个类来完成前文描述的功能:

  1. >>> json.JSONDecoder().decode('{"a": 123}')
  2. {'a': 123}
  3. >>> json.JSONEncoder().encode({'a': 123})
  4. '{"a": 123}'

json.loads, json.load, json.dumpsjson.dump这个四个方法的参数主要都是传递给了json.JSONDecoderjson.JSONEncoder的构造方法, 所以使用这些方法可以满足绝大部分需求. 当需要自定义json.JSONDecoderjson.JSONEncoder子类的时候, 只需要将子类传递给cls参数. 同时, 这些方法都有**kw参数. 当自定义实现类的构造函数需要标准参数列表之外的新参数时, 这个参数就会将新参数传递给实现类的构造方法.

5 相关资源

Python 3 中的json模块使用的更多相关文章

  1. Python学习笔记:json模块和pickle模块(数据序列化)

    Python中的json模块和pickle都是用于数据的序列化和反序列化,它们提供的方法也是一样的:dumps,dump,loads,load dumps(obj):将对象序列化为str. dump( ...

  2. Python编程中 re正则表达式模块 介绍与使用教程

    Python编程中 re正则表达式模块 介绍与使用教程 一.前言: 这篇文章是因为昨天写了一篇 shell script 的文章,在文章中俺大量调用多媒体素材与网址引用.这样就会有一个问题就是:随着俺 ...

  3. openresty开发系列25--openresty中使用json模块

    openresty开发系列25--openresty中使用json模块 web开发过程中,经常用的数据结构为json,openresty中封装了json模块,我们看如何使用 一)如何引入cjson模块 ...

  4. Python中的json模块

    在Python内置函数中,有一个eval()函数可以将字符串内容转换成Python对象,比如我现在将一个字典 dic = {"name":"pengfy"}写到 ...

  5. python中序列化json模块和pickle模块

    内置模块和第三方模块 json模块和pickle 模块(序列化模块) 什么是序列化? 序列化就是将内粗这种的数据类型转成另一种格式 序列化:字典类型——>序列化——>其他格式——>存 ...

  6. python中的 json 模块使用

    (1)python 中生成 json 字符串: import json data = dict(ret=0, msg="Welcome, Login success!") json ...

  7. Python中的Json模块dumps、loads、dump、load函数介绍

    Json模块dumps.loads.dump.load函数介绍 1.json.dumps() json.dumps() 用于将dict类型的数据转成str,因为如果直接将dict类型的数据写入json ...

  8. Python序列化-pickle和json模块

    Python的“file-like object“就是一种鸭子类型.对真正的文件对象,它有一个read()方法,返回其内容.但是,许多对象,只要有read()方法,都被视为“file-like obj ...

  9. python爬虫中的requests模块

    Requests: 让 HTTP 服务人类 一.简介 虽然Python的标准库中 urllib 模块已经包含了平常我们使用的大多数功能,但是它的 API 使用起来让人感觉不太好,而 Requests ...

随机推荐

  1. (NO.00005)iOS实现炸弹人游戏(十):游戏主角(三)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 下面我们来看游戏主角类里面几个播放特殊动画的方法,首先从run ...

  2. (一一八)利用block实现链式编程

    有些时候需要不断地调用方法,如果使用传统方案,需要拿到对象多次调用,例如有一个Ball对象,实现了up.down.left.right四个方法,分别控制球的运动方向,如果要实现球向右再向下,需要这么写 ...

  3. 后端分布式系列:分布式存储-HDFS DataNode 设计实现解析

    前文分析了 NameNode,本文进一步解析 DataNode 的设计和实现要点. 文件存储 DataNode 正如其名是负责存储文件数据的节点.HDFS 中文件的存储方式是将文件按块(block)切 ...

  4. 1049. Counting Ones (30)

    题目如下: The task is simple: given any positive integer N, you are supposed to count the total number o ...

  5. UNIX网络编程——shutdown 与 close 函数 的区别

    假设server和client 已经建立了连接,server调用了close, 发送FIN 段给client(其实不一定会发送FIN段,后面再说),此时server不能再通过socket发送和接收数据 ...

  6. HMM:隐马尔科夫模型-维特比算法

    http://blog.csdn.net/pipisorry/article/details/50731584 目标-解决HMM的基本问题之二:给定观察序列O=O1,O2,-OT以及模型λ,如何选择一 ...

  7. 【unix网络编程第三版】ubuntu端口占用问题

    <unix网络编程>一书中的代码并不是能直接运行,有时候需要结合各方面的知识来解决,大家在这本书的时候,一定要把代码都跑通,不难你会错过很多学习的机会! 1.问题描述 本人在阅读<U ...

  8. Android LK Bootlaoder启动概览

    LK - Little kernel 1. 起源地: bootable\bootloader\lk\arch\arm (1)rule.mk $(BUILDDIR)/trustzone-test-sys ...

  9. 分布式进阶(三)Ubuntu 14.04 之JDK安装

    Ubuntu 10.04 之JDK安装 1.从官网 (http://www.Oracle.com/technetwork/java/javase/downloads/jdk6u35-downloads ...

  10. 【一天一道LeetCode】#84. Largest Rectangle in Histogram

    一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given n ...