当前位置: 代码迷 >> 综合 >> python json.dumps() json.dump()的区别
  详细解决方案

python json.dumps() json.dump()的区别

热度:71   发布时间:2023-11-26 02:11:38.0

dumps是将dict转化成str格式,loads是将str转化成dict格式。

dump和load也是类似的功能,只是与文件操作结合起来了。

 

看代码实例:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
In [ 1 ]:  import  json
In [ 2 ]: a  =  { 'name' 'wang' 'age' 29 }
In [ 3 ]: b  =  json.dumps(a)
In [ 4 ]:  print  b,  type (b)
{ "age" 29 "name" "wang" } < type  'str' >
In [ 11 ]: json.loads(b)
Out[ 11 ]: {u 'age' 29 , u 'name' : u 'wang' }
In [ 12 ]:  print  type (json.loads(b))
< type  'dict' >

 

然后再看dump和dumps的区别,见代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
In [ 1 ]:  import  json
In [ 2 ]: a  =  { 'name' 'wang' 'age' 29 }
In [ 3 ]: b  =  json.dumps(a)
In [ 4 ]:  print  b,  type (b)
{ "age" 29 "name" "wang" } < type  'str' >
In [ 5 ]: c  =  json.dump(a)
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
TypeError                                 Traceback (most recent call last)
<ipython - input - 5 - 92dc0d929363 in  <module>()
- - - - 1  =  json.dump(a)
TypeError: dump() takes at least  2  arguments ( 1  given)

 

这里提示我们少一个参数,我们看一下帮助文件(iPyhton中可以直接使用help(json.dumps)来查看帮助文件):

 

dumps(obj, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', default=None, sort_keys=False, **kw)
Serialize ``obj`` to a JSON formatted ``str``.

 

dump(obj, fp, skipkeys=False, ensure_ascii=True, check_circular=True, allow_nan=True, cls=None, indent=None, separators=None, encoding='utf-8', default=None, sort_keys=False, **kw)
Serialize ``obj`` as a JSON formatted stream to ``fp`` (a
``.write()``-supporting file-like object).

 

简单说就是dump需要一个类似于文件指针的参数(并不是真的指针,可称之为类文件对象),可以与文件操作结合,也就是说可以将dict转成str然后存入文件中;而dumps直接给的是str,也就是将字典转成str。

例子见代码(注意文件操作的一些小细节):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
In [ 1 ]:  import  json
In [ 2 ]: a  =  { 'name' 'wang' }
In [ 3 ]: fp  =  file ( 'test.txt' 'w' )
In [ 4 ]:  type (fp)
Out[ 4 ]:  file
In [ 5 ]: json.dump(a, fp)
In [ 6 ]: cat test.txt
In [ 7 ]: fp.close()
In [ 8 ]: cat test.txt
{ "name" "wang" }
In [ 9 ]: json.load(fp)
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
ValueError                                Traceback (most recent call last)
<ipython - input - 9 - 0064dabedb17 in  <module>()
- - - - 1  json.load(fp)
/ usr / local / Cellar / python / 2.7 . 11 / Frameworks / Python.framework / Versions / 2.7 / lib / python2. 7 / json / __init__.pyc  in  load(fp, encoding,  cls , object_hook, parse_float, parse_int, parse_constant, object_pairs_hook,  * * kw)
     285
     286      """
- - 287      return  loads(fp.read(),
     288          encoding = encoding,  cls = cls , object_hook = object_hook,
     289          parse_float = parse_float, parse_int = parse_int,
ValueError: I / O operation on closed  file
In [ 10 ]: fp  =  file ( 'test.txt' 'r' )
In [ 11 ]: json.load(fp)
Out[ 11 ]: {u 'name' : u 'wang' }

  

注:实际中dump用的较少。 


在使用json.dumps时要注意一个问题

>>> import json
>>> print json.dumps('中国')
"\u4e2d\u56fd"
输出的会是
'中国' 中的ascii 字符码,而不是真正的中文。
这是因为json.dumps 序列化时对中文默认使用的ascii编码.想输出真正的中文需要指定ensure_ascii=False:
>>> import json
>>> print json.dumps('中国')
"\u4e2d\u56fd"
>>> print json.dumps('中国',ensure_ascii=False)
"中国"
>>> 

 

 

  相关解决方案