• Python dict(或对象)与json之间的互相转化


    Python dict(或对象)与json之间的互相转化

    原文转载自Python之dict(或对象)与json之间的互相转化

    1.JSON:JavaScript 对象表示法,是轻量级的文本数据交换格式,独立于语言,平台

    2.JSON 语法规则

    • 数据在名称/值对中
    • 数据由逗号分隔
    • 花括号保存对象
    • 方括号保存数组

    3.json例子

    name = { "firstName":"John" , "lastName":"Doe" } #花括号 键值对 表对象
    
    employees = { #方括号 数组可包含多个对象
    "employees": [
    { "firstName":"John" , "lastName":"Doe" },
    { "firstName":"Anna" , "lastName":"Smith" },
    { "firstName":"Peter" , "lastName":"Jones" }
    ]
    }
    

    4.JSON /dict/对象 互相转换

    使用python自带json库 其主要方法只有两个dump load/dumps loads

    带's'的版本意为'str', json格式的字符串.

    loads():将json数据转化成dict数据
    dumps():将dict数据转化成json数据
    load():读取json文件数据,转成dict数据
    dump():将dict数据转化成json数据后写入json文件
    import json  #导入
    

    dict 转 json

    j = json.dumps(employees)
    print(j)
    
    {"employees": [{"firstName": "John", "lastName": "Doe"}, {"firstName": "Anna", "lastName": "Smith"}, {"firstName": "Peter", "lastName": "Jones"}]}
    

    json 转dict

    # 将json格式的字符串转换成json对象
    jsonstr = '{"employees":  
               [{"firstName": "John", "lastName": "Doe"},
               {"firstName": "Anna", "lastName": "Smith"},
               {"firstName": "Peter", "lastName": "Jones"}]
              }'
    d = json.loads(jsonstr)
    print(d)
    print(type(d))
    
    {'employees': [{'firstName': 'John', 'lastName': 'Doe'}, {'firstName': 'Anna', 'lastName': 'Smith'}, {'firstName': 'Peter', 'lastName': 'Jones'}]}
    <class 'dict'>
    

    对象转dict

    ##### 对象的 属性名:属性值 组成的键值对  就成了一个dict
    class Employee:
        def __init__(self,firstname,lastname):
            self.firstname=firstname
            self.lastname=lastname
    e1 = Employee('John','Doe')
    print(e1.__dict__)
    
    {'firstname': 'John', 'lastname': 'Doe'}
    

    再转json

    e1 = e1.__dict__
    j1 = json.dumps(e1)
    print(j1)
    print(type(j1))
    
    {"firstname": "John", "lastname": "Doe"}
    <class 'str'>
    

    直接从对象转json

    jsonstr = json.dumps(Employee('乌鸡','张'),ensure_ascii=False,indent=4,default=lambda o:o.__dict__)
    print(jsonstr)  #ensure_ascii=False,才能原样显示中文,否则默认转换成'u5f20'这样的 unicode-escape编码
    
    {
        "firstname": "乌鸡",
        "lastname": "张"
    }
    

    json的load()与dump()方法的使用

    with open('employee.json', 'w') as f:
            json.dump(e1, f)  # 会在目录下生成一个1.json的文件,文件内容是dict数据转成的json数据
    
    with open('employee.json','r') as f:
        d =json.load(f)
    print(d)
    
    {'firstname': 'John', 'lastname': 'Doe'}
    
    
    
  • 相关阅读:
    Hadoop 单机搭建 Scala安装
    Hadoop 单机搭建 Hbase单机模式搭建
    Hadoop 单机搭建 hadoop单机搭建
    Linux shell 重定向学习笔记
    转:SQLServer中的GROUPING,ROLLUP和CUBE
    ueditor getshell漏洞重现及分析
    SQLServer禁用、启用外键约束
    转:Sql Server中清空所有数据表中的记录
    EF结合SqlBulkCopy实现高效的批量数据插入 |EF插件EntityFramework.Extended实现批量更新和删除
    12种开源Web安全扫描程序
  • 原文地址:https://www.cnblogs.com/ShawSpring/p/10681015.html
Copyright © 2020-2023  润新知