zoukankan      html  css  js  c++  java
  • python解析json文件之简介

    一、JSON简介

      JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。
         JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

      JSON建构于两种结构:

      “名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array)。 值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交换成为可能。

    二、引用模块 

    import json
    View Code

    三、相关函数

      1.编码(encode):把一个python对象编码转换成json字符串 json.dumps()
      2.解码(decode):把json格式字符串解码转换成python对象 json.loadS()

    四、具体实例

    实例一:json.dumps()

    import json
    
    s = json.loads('{"name":"test","type":{"name":"seq","parameter":["1","2"]}}')
    print type(s)
    print s.keys()
    print s["name"]
    print s["type"]
    print s["type"]["name"]
    View Code

    程序执行结果如下:

    <type 'dict'>
    [u'type', u'name'] #此处输出结果:可以看出字典是无序的
    test
    {u'parameter': [u'1', u'2'], u'name': u'seq'}
    seq
    View Code

    实例二:json.dumps()  json.loads()

    import json  
    
    
    data = {'a':123,'b':[1,2]}
    d1 = json.dumps(data)
    print type(data)
    print type(d1)
    print len(d1)
    print d1
    for i in range(len(d1)):
    print d1[i]
    
    d2 = json.loads(d1)
    print type(d2)
    print d2
    print d2.keys()
    print d2.values()
    for k in d2.keys():
    print k,d2[k]
    View Code

    实例三

    import json
    
    
    #encode
    obj = [[1,2,3],123,123.123,'abc',{'key1':(1,2,3),'key2':(4,5,6)}]
    print type(obj)
    encodedjson = json.dumps(obj)
    print type(encodedjson)
    print len(encodedjson)
    print repr(obj)
    print encodedjson
    
    
    #decode
    decodejson = json.loads(encodedjson)
    print type(decodejson)
    print decodejson[4]['key1']
    print decodejson
    View Code

    程序执行结果:

    <type 'list'>
    <type 'str'>
    72
    [[1, 2, 3], 123, 123.123, 'abc', {'key2': (4, 5, 6), 'key1': (1, 2, 3)}]
    [[1, 2, 3], 123, 123.123, "abc", {"key2": [4, 5, 6], "key1": [1, 2, 3]}]
    <type 'list'>
    [1, 2, 3]
    [[1, 2, 3], 123, 123.123, u'abc', {u'key2': [4, 5, 6], u'key1': [1, 2, 3]}]
    View Code

      通过输出的结果可以看出,简单类型通过encode之后跟其原始的repr()输出结果非常相似,但是有些数据类型进行了改变,例如上例中的元组则转换为了列表。在json的编码过程中,会存在从python原始类型向json类型的转化过程,具体的转化对照如下:

    image

      loads方法返回了原始的对象,但是仍然发生了一些数据类型的转化。比如,上例中‘abc’转化为了unicode类型。从json到python的类型转化对照如下:

    image

    json.dumps方法提供了很多好用的参数可供选择,比较常用的有sort_keys(对dict对象进行排序,我们知道默认dict是无序存放的),separators,indent等参数。

    五、排序

    data1 = {'b':789,'c':456,'a':123}
    data2 = {'a':123,'b':789,'c':456}
    print type(data1)
    print type(data2)
    d1 = json.dumps(data1,sort_keys=True)
    print type(d1)
    print d1
    
    #此处是for循环,将json字符串打印输出
    print len(d1)
    for i in range(30):
    print d1[i]
    
    for i in range(len(d1)):
    print d1[i]
    View Code

    需要注意的知识点:当字典转换成json字符串之后,每一个字符都是一个单独的元素,和我们通常意义上理解的字符串就不同了,不过依然可以通过下标的方式来进行获取

    完整的代码如下:

    data1 = {'b':789,'c':456,'a':123}
    data2 = {'a':123,'b':789,'c':456}
    print type(data1)
    print type(data2)
    d1 = json.dumps(data1,sort_keys=True)
    print type(d1)
    d2 = json.dumps(data2)
    print type(d2)
    d3 = json.dumps(data2,sort_keys=True)
    print d1
    print d2 
    print d3
    print d1 == d2
    print d1 == d3
    View Code

    程序输出结果:

    <type 'dict'>
    <type 'dict'>
    <type 'str'>
    <type 'str'>
    {"a": 123, "b": 789, "c": 456}
    {"a": 123, "c": 456, "b": 789}
    {"a": 123, "b": 789, "c": 456}
    False
    True
    View Code

    说明:
        本来data1和data2数据应该是一样的,但是由于dict存储的无序特性,造成两者无法比较。因此两者可以通过排序后的结果进行存储就避免了数据比较不一致的情况发生,
    但是排序后再进行存储,系统必定要多做一些事情,也一定会因此造成一定的性能消耗,所以适当排序是很重要的

    六、缩进参数

    import json
    data1 = {'b':789,'c':456,'a':123}
    d1 = json.dumps(data1,sort_keys=True,indent=4)
    print type(data1)
    print type(d1)
    print d1
    print len(d1)
    
    #for循环:依次将json字符串打印输出
    for i in range(len(d1)):
    print d1[i]
    View Code

    程序执行结果如下:

    <type 'dict'>
    <type 'str'>
    {
    "a": 123, 
    "b": 789, 
    "c": 456
    }
    View Code

    indent参数是缩进的意思,它可以使得数据存储的格式变得更加优雅

    七、压缩

    import json
    a = {'a': 123,'c': 456,'b': 789}
    print type(a)
    print a
    print len(repr(a))
    
    b = json.dumps(a,separators=(',',':'))
    print type(b)
    print b
    print len(repr(b))
    View Code

    程序执行结果:

    <type 'dict'>
    {'a': 123, 'c': 456, 'b': 789}
    30
    <type 'str'>
    {"a":123,"c":456,"b":789}
    27
    View Code

    八、参考文章

    http://www.cnblogs.com/kaituorensheng/p/3877382.html

    http://www.cnblogs.com/coser/archive/2011/12/14/2287739.html

  • 相关阅读:
    在字符串中,找出第一个不重复的字符
    servlet/filter/listener/interceptor区别与联系
    Java基础--泛型
    Java基础--访问权限控制符
    Comparable与Comparator的区别
    表示层设计模式:Intercepting Filter(截取筛选器)模式
    Java多线程:线程同步与关键字synchronized
    Java多态-如何理解父类引用指向子类对象
    android 垂直 SeekBar 源代码(VerticalSeekBar)[转]
    回调接口
  • 原文地址:https://www.cnblogs.com/yamei/p/5504893.html
Copyright © 2011-2022 走看看