zoukankan      html  css  js  c++  java
  • Python json详解

    什么是JSON

    JSON是一种取代XML的数据结构,和xml相比,它更小巧但描述能力却不差,由于它的小巧所以网络传输数据将减少更多流量从而加快速度。

    那么,JSON到底是什么?

    JSON就是一串字符串 只不过元素会使用特定的符号标注。

    { } 双括号表示对象

    [ ] 中括号表示数组

    " " 双引号内是属性或值

    : 冒号表示后者是前者的值(这个值可以是字符串、数字、也可以是另一个数组或对象)

    所以 {"name": "Michael"} 可以理解为是一个包含name为Michael的对象

    而[ {"name": "Michael"} , {"name": "Jerry"} ]就表示包含两个对象的数组

    当然了,你也可以使用{ "name"  :  ["Michael" , "Jerry"] }来简化上面一部,这是一个拥有一个name数组的对象

    PS:现在还有很多人存在一些误区,为什么{name:'json'}在检验时通过不了, 那是因为JSON官网最新规范规定,如果是字符串,那不管是键或值最好都用双引号引起来,所以上面的代码就是{"name":"json"}

     1 var people = { "programmers": [
     2  
     3 { "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" },
     4  
     5 { "firstName": "Jason", "lastName":"Hunter", "email": "bbbb" },
     6  
     7 { "firstName": "Elliotte", "lastName":"Harold", "email": "cccc" }
     8  
     9 ],
    10  
    11 "authors": [
    12  
    13 { "firstName": "Isaac", "lastName": "Asimov", "genre": "science fiction" },
    14  
    15 { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },
    16  
    17 { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }
    18  
    19 ],
    20  
    21 "musicians": [
    22  
    23 { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },
    24  
    25 { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }
    26  
    27 ] }

    访问数据

    尽管看起来不明显,但是上面的长字符串实际上只是一个数组;将这个数组放进 JavaScript 变量之后,就可以很轻松地访问它。

    实际上,只需用点号表示法来表示数组元素。所以,要想访问 programmers 列表的第一个条目的姓氏,

    只需在 JavaScript 中使用下面这样的代码:

    people.programmers[0].lastName;

    注意,数组索引是从零开始的。所以,这行代码首先访问 people变量中的数据;然后移动到称为 programmers的条目,

    再移动到第一个记录([0]);最后,访问 lastName键的值。结果是字符串值 “McLaughlin”。

    修改 JSON 数据

    正如可以用点号和括号访问数据,也可以按照同样的方式轻松地修改数据:

    people.musicians[1].lastName = "Rachmaninov";

    在将字符串转换为 JavaScript 对象之后,就可以像这样修改变量中的数据。

    转换回字符串

    当然,如果不能轻松地将对象转换回本文提到的文本格式,

    那么所有数据修改都没有太大的价值。在 JavaScript 中这种转换也很简单:

    String newJSONtext = people.toJSONString();

    这样就行了!现在就获得了一个可以在任何地方使用的文本字符串,

    例如,可以将它用作 Ajax 应用程序中的请求字符串。

    更重要的是,可以将任何JavaScript 对象转换为 JSON 文本。并非只能处理原来用 JSON 字符串赋值的变量。

    为了对名为 myObject的对象进行转换,只需执行相同形式的命令:

    String myObjectInJSON = myObject.toJSONString();

    这就是 JSON 与本系列讨论的其他数据格式之间最大的差异。如果使用 JSON,

    只需调用一个简单的函数,就可以获得经过格式化的数据,可以直接使用了。

    对于其他数据格式,需要在原始数据和格式化数据之间进行转换。

    即使使用 Document Object Model 这样的 API(提供了将自己的数据结构转换为文本的函数),

    也需要学习这个 API 并使用 API 的对象,而不是使用原生的 JavaScript 对象和语法。

    最终结论是,如果要处理大量 JavaScript 对象,那么 JSON 几乎肯定是一个好选择,

    这样就可以轻松地将数据转换为可以在请求中发送给服务器端程序的格式。

  • 相关阅读:
    PointToPointNetDevice doesn't support TapBridgeHelper
    NS3系列—10———NS3 NodeContainer
    NS3系列—9———NS3 IP首部校验和
    NS3系列—8———NS3编译运行
    【习题 7-6 UVA
    【Good Bye 2017 C】 New Year and Curling
    【Good Bye 2017 B】 New Year and Buggy Bot
    【Good Bye 2017 A】New Year and Counting Cards
    【Educational Codeforces Round 35 D】Inversion Counting
    【Educational Codeforces Round 35 C】Two Cakes
  • 原文地址:https://www.cnblogs.com/rainbow-1/p/14556424.html
Copyright © 2011-2022 走看看