1. 说明:
    #json是一种通用的数据类型,所有的语言都认识。
    #k - v {}
    #json串就是一个字符串,不能根据key-value取值
    #json可以转成字典
    #json串就是字符串,可放在三引号中
    校验json格式的网址:http://www.bejson.com/
    那么json怎么转成字典,用到模块json,可以import json

一、JSON 函数

1、json.dumps:字典转成json串(字符串)

  1. json.dumps(stus,indent=8,ensure_ascii=False) #将字典转成json字符串 ;indent 控制几个缩进的;当字典中有中文的时候,需要写ensure_ascii=False,不然json串里面不显示汉字。

2、json.loads:将json串转成字典

1)字典和json互相转换:

  1. import json #导入json模块
  2. s = '''
  3. {
  4. "error_code": 0,
  5. "stu_info": [
  6. {
  7. "id": 309,
  8. "name": "小白",
  9. "sex": "男",
  10. "age": 28,
  11. "addr": "河南省济源市北海大道32号",
  12. "grade": "天蝎座",
  13. "phone": "18512572946",
  14. "gold": 100
  15. },
  16. {
  17. "id": 310,
  18. "name": "小白",
  19. "sex": "男",
  20. "age": 28,
  21. "addr": "河南省济源市北海大道32号",
  22. "grade": "天蝎座",
  23. "phone": "18516572946",
  24. "gold": 100
  25. }
  26. ]
  27. }
  28. '''
  29. res = json.loads(s) #将json串转成字典
  30. print(res)
  31. print(type(res))
  32. stus = {'xiaojun':'','xiaohei':''} #一个字典
  33. res2 = json.dumps(stus) #将字典转成json串
  34. print(res2)
  35. print(type(res2))

2)字典转成json串,然后写入文件

  1. stus = {'xiaojun':'','xiaohei':'','海龙':''} #一个字典
  2. res2 = json.dumps(stus,indent=8,ensure_ascii=False) #将字典转成json串
  3. print(res2)
  4. print(type(res2))
  5. with open('stus.json','w',encoding='utf-8') as f: #文件的后缀.json,这样文件里面显示的好看,有颜色区分。后缀无所谓
  6. f.write(res2)

文件中看-实际带有颜色:

  1. {
  2. "xiaohei": "",
  3. "海龙": "",
  4. "xiaojun": ""
  5. }

3)从文件中读取json串,转成字典

  1. with open('stus.json','r',encoding='utf-8')as f:
  2. content = f.read() #返回字符串
  3. user_dict = json.loads(content) #将json字符串转成字典
  4. print(user_dict)

3、json.load()与json.loads()的区别

两个方法功能类似,可选参数也相同,最大的区别在于,json.load方法接受的输入,即第一个参数,是包含json数据的文件对象,如open方法的返回对象。

json.loads接受的输入是json字符串,而非文件对象。

如果说你要操作文件,可以直接用json.load

举例:

json.loads()将文件中的json转成字典如下:

  1. with open('stus.json','r',encoding='utf-8')as f:
  2. content = f.read() #返回字符串
  3. user_dict = json.loads(content) #json.loads接受的是字符串content
  4. print(user_dict)

json.load()将文件中的json转成字典如下:

  1. with open('stus.json','r',encoding='utf-8')as f:
  2. user_dic = json.load(f) #json.load接受的是文件对象
  3. print(user_dic)

4、json.dump()和json.dumps()区别

dump()第一个参数时字典对象,第二个参数是文件对象,可以直接将转换后的json数据写入文件;dumps的第一个参数是对象字典,其余都是可选参数。

参数记录如下:

ensure_ascii 默认为True,保证转换后的json字符串中全部是ascii字符,非ascii字符都会被转义。如果数据中存在中文或其他非ascii字符,最好将ensure_ascii设置为False,保证输出结果正常。

indent 缩进,默认为None,没有缩进,设置为正整数时,输出的格式将按照indent指定的半角空格数缩进,相当实用。

separators 设置分隔符,默认的分隔符是(',', ': '),如果需要自定义json中的分隔符,例如调整冒号前后的空格数,可以按照(item_separator, key_separator)的形式设置。

sort_keys 默认为False,设为True时,输出结果将按照字典中的key排序。

将字典转成json串写入文件操作:

json.dumps()方式

  1. stus = {'xiaojun':'','xiaohei':'','海龙':''}
  2. f = open('stus.json','w',encoding='utf-8')
  3. res = json.dumps(stus,indent=8,ensure_ascii=False) #转换成json串
  4. f.write(res) #写入文件

json.dump()方式:

  1. stus = {'xiaojun':'','xiaohei':'','海龙':''}
  2. f = open('stus.json','w',encoding='utf-8')
  3. json.dump(stus,f,indent=8,ensure_ascii=False) #json.dump第一个参数字典(stus),第二个参数文件对象(f),这个不需要再写入操作了,直接就写进去了

以上:当你要把字典写到文件里面,用dump比较好用。如果你不操作文件,想存到数据库里面,不能用dump,还得用dumps.

不带s都跟文件相关,带s的都跟字符串相关。

问题:应用json.load/loads/dump/dumps方法时,文件中的内容如果不是json格式会抛异常如下。

raise JSONDecodeError("Expecting value", s, err.value) from None
json.decoder.JSONDecodeError: Expecting value: line 1 column 1 (char 0)

原因:文件中不是json格式,可用http://www.bejson.com/查询是不是json格式,其中:文件是空的不是json格式,1也是json格式,{}是json格式

如果起初文件就是空的,可以写个{}这样就能正确解析json串了

day4_处理json的更多相关文章

  1. 使用TSQL查询和更新 JSON 数据

    JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...

  2. 【疯狂造轮子-iOS】JSON转Model系列之二

    [疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...

  3. 【疯狂造轮子-iOS】JSON转Model系列之一

    [疯狂造轮子-iOS]JSON转Model系列之一 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 之前一直看别人的源码,虽然对自己提升比较大,但毕竟不是自己写的,很容易遗 ...

  4. Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)

    背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...

  5. .NET Core系列 : 2 、project.json 这葫芦里卖的什么药

    .NET Core系列 : 1..NET Core 环境搭建和命令行CLI入门 介绍了.NET Core环境,本文介绍.NET Core中最重要的一个配置文件project.json的相关内容.我们可 ...

  6. 一个粗心的Bug,JSON格式不规范导致AJAX错误

    一.事件回放  今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...

  7. JSON.parse()和JSON.stringify()

    1.parse 用于从一个字符串中解析出json 对象.例如 var str='{"name":"cpf","age":"23&q ...

  8. json与JavaScript对象互换

    1,json字符串转化为JavaScript对象: 方法:JSON.parse(string) eg:var account = '{"name":"jaytan&quo ...

  9. .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator

    去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...

随机推荐

  1. visio2013激活软件

    环境是 win7, 64 bit 装了 visio 2013 , 可以却不能用它来画图,在网上找了一些破解工具,大都不能解决问题.网上不靠谱的广告型文章太多了,比较头痛. 所幸,终于找到正确的破解工具 ...

  2. cuda和显卡驱动版本

    TensorFlow安装时需要cuda+对应的显卡驱动.这里给出英伟达官方的cuda和驱动的对应: 地址在这里 然后在这里可下载最新的显卡驱动(英伟达公版的驱动,程序员友好型) 最后说一下我的Tens ...

  3. masscan

    masscan是一个快速的端口扫描工具 大概说一下它的使用方法,既有原创也有翻译 欢迎补充 扫描10.x.x.x的网络:masscan 10.0.0.0/8 -p80 程序将自动探测网络的接口和适配器 ...

  4. Public key for ambari-server-2.4.2.0-136.x86_64.rpm is not installed 安装ambari报错总结

    提示;# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-redhat-release 就是导入这个安装包的key 可以使用http的协议 比如我用的就是 rpm ...

  5. centos 7 配置tomcat开机启动

    1. tomcat 需要增加一个pid文件 在tomca/bin 目录下面,增加 setenv.sh 配置,catalina.sh启动的时候会调用,同时配置java内存参数. #add tomcat ...

  6. File 类的 getCanonicalFile( ) 和 getAbsoluteFile( ) 区别

    一.打开java.io.File源码,看下两个方法的区别 getAbsoluteFile public File getAbsoluteFile() { String absPath = getAbs ...

  7. [C#] 一款代码注释清理工具

    [C#] 一款代码注释清理工具   在程序开发过程中,很多时候我们都会在代码中进行注释,以便大家更容易理解或能更直观明白某个类或方法是用来做什么的,我们就会用注释 就以C#为列子,注释符大致为'//' ...

  8. Spark学习笔记——数据读取和保存

    spark所支持的文件格式 1.文本文件 在 Spark 中读写文本文件很容易. 当我们将一个文本文件读取为 RDD 时,输入的每一行 都会成为 RDD 的 一个元素. 也可以将多个完整的文本文件一次 ...

  9. 在linux中安装字体

    https://blog.csdn.net/wangxintong_1992/article/details/81194896

  10. WPF之依赖属性和附加属性

     参考资料: 一站式WPF--依赖属性(DependencyProperty)一 一站式WPF--依赖属性(DependencyProperty)二         依赖属性之我见: 这两篇文章介绍的 ...