专栏首页python3python3操作json

python3操作json

json本身就是一种字符串。


# 需要导入模块包
import json

1,将字符串转为json格式

s1 = "{'key1':'value1','key2':'value2'}"
print(s1)
print(type(s1))
js1 = json.dumps(s1)
print(js1)
print(type(js1))

结果:
{'key1':'value1','key2':'value2'}
<class 'str'>
"{'key1':'value1','key2':'value2'}"
<class 'str'>

结论: dumps就是把字符串外面又加了一层引号。

2,将json解析为字符串

s2 = json.loads(js1)
print(s2)
print(type(s2))

结果:
{'key1':'value1','key2':'value2'}
<class 'str'>

结论: 正好与dumps相反,减掉了最外层的引号。

3,字典转json

d1 = {'key1':'value1','key2':'value2'}
print(d1)
print(type(d1))
js2 = json.dumps(d1)
print(js2)
print(type(js2))

结果:
{'key1': 'value1', 'key2': 'value2'}
<class 'dict'>
{"key1": "value1", "key2": "value2"}
<class 'str'>

结论: 效果非常有意思。尤其是与《字符串转json》对比一下。如果仅仅看最后得出来的数据的话,根本是看不出来。

4,json转字典

d2 = eval(js2)
print(d2)
print(type(d2))

结果:
{'key1': 'value1', 'key2': 'value2'}
<class 'dict'>

5,再作个对比:字符串转字典

d3 = eval(s1)
print(d3)
print(type(d3))

结果:
{'key1': 'value1', 'key2': 'value2'}
<class 'dict'>

结论: 可以看到,eval对于json和字符串的操作是相同的。


最终:

如果想操作json,最终的操作都可以转为Python的字典类型进行操作。 当然,不是非要这么做。

挺有意思的。


接收来自网页的json字符串,就一定要用loads加载一下才可以。如果要是直接使用eval的话,数据会有问题。


直接操作文件

import json

json_str = {'key1': 'value1', 'key2': 'value2'}

# 写入文件
# 可以通过json包,将json串(可以是字符串类型、字典类型、json类型)直接写入到文件中
with open('something.json') as sjw:
    json.dump(json_str, sjw)

# 读取文件
json_read = json.load('something.json')
print(json_read)
json_read.close()

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python解析与组装json

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3...

    py3study
  • Python- Json模块

    py3study
  • Python爬虫爬取百度翻译之数据提取方法

    工具:Python 3.6.5、PyCharm开发工具、Windows 10 操作系统

    py3study
  • Python- Json模块

    py3study
  • MySQL向MongoDB的妥协之JSON

    MySQL在5.7.8版本中增加了对json数据的支持,而不再是需要使用字符串形式进行存储。下面简单介绍下MySQL对json的操作:

    Jean
  • Python爬虫爬取百度翻译之数据提取方法

    工具:Python 3.6.5、PyCharm开发工具、Windows 10 操作系统

    py3study
  • oracle mysql5.7 Json函数

    oracle mysql 5.7.8 之后增加了对json数据格式的函数处理,可更加灵活的在数据库中操作json数据,如可变属性、自定义表单等等都使用使用该方式...

    兜兜毛毛
  • Greenplum数据库使用总结(干货满满)--对JSON的支持

    JSON作为结构化的数据,目前越来越受到开发者的爱戴,它简单灵活易于理解。是作为储存数据的一种比较使用的一种格式,greenplum从5.0开始便很好的支持了J...

    小徐
  • json字符串和字典的区别

    json字符串和字典的区别: json: (JavaScript Object Notation)的首字母缩写,字面的意思是(javascript对象表示法...

    武军超
  • python解析与组装json

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3...

    py3study

扫码关注云+社区

领取腾讯云代金券