利用SuperObject 循环处理Json深层次的值
2015-03-27 16:33
260 查看
<pre name="code" class="delphi">procedure TForm1.Button5Click(Sender: TObject); var item,jo: ISuperObject; ja,JA_TYPE,JA_MAC:TSuperArray; //json数组 i,j,k:Integer; jts: TSuperTableString; //TSuperTableString 的常用属性: count、GetNames、GetValues begin jo := SO(Memo1.Text); jts:=jo.AsObject; mmo1.Lines.Add('结点数:'+IntToStr(jts.count )); mmo1.Lines.Add('键名:'+jts.GetNames.AsString); mmo1.Lines.Add('键值:'+jts.GetValues.AsString); jts:=jo['addresses'].AsObject; mmo1.Lines.Add('结点数:'+IntToStr(jts.count )); mmo1.Lines.Add(jts.GetNames.AsString); mmo1.Lines.Add('键值:'+jts.GetValues.AsString); jts:=jo.A['children'].N[0].AsObject; mmo1.Lines.Add('结点数:'+IntToStr(jts.count )); mmo1.Lines.Add(jts.GetNames.AsString); mmo1.Lines.Add('键值:'+jts.GetValues.AsString); jts:=jo.A['children'].N[0].A['M_TYPE'].N[0].AsObject; mmo1.Lines.Add('结点数:'+IntToStr(jts.count )); mmo1.Lines.Add(jts.GetNames.AsString); mmo1.Lines.Add('键值:'+jts.GetValues.AsString); jts:=jo.A['children'].N[0].A['M_TYPE'].N[0].A['MACHINE'].N[0].AsObject; mmo1.Lines.Add('结点数:'+IntToStr(jts.count )); mmo1.Lines.Add(jts.GetNames.AsString); mmo1.Lines.Add('键值:'+jts.GetValues.AsString); ja:=jo.A['children']; //等同 ja:=jo.O['children'].AsArray; for i := 0 to ja.Length-1 do begin mmo1.Lines.Add('店主:'+ja.O[i].s['name']); //区分大小写 JA_TYPE:=ja.O[i].O['M_TYPE'].AsArray; for j := 0 to ja_type.Length-1 do begin mmo1.Lines.Add('出票类型:'+IntToStr(JA_TYPE.O[j].I['MACHINE_TYPE'])); mmo1.Lines.Add('出票类型名:'+JA_TYPE.O[j].s['MACHINE_NAME']); JA_MAC:=JA_TYPE.O[j].O['MACHINE'].AsArray; for k := 0 to ja_mac.Length-1 do begin mmo1.Lines.Add('机器编号:'+JA_MAC.O[k].s['MACHINE_NO']); mmo1.Lines.Add('机器状态:'+IntToStr(JA_MAC.O[k].I['STATUS'])); mmo1.Lines.Add('机器余额:'+FloatToStr(JA_MAC.O[k].D['BALANCE'])); end; end; end; // for item in jo do ShowMessage(item.AsJSon(False, False)); end;//--------------------------Json格式如下
{ "name": "张三", "age": 33, "sex": true, "weight": 123.456, "tel": [ "86-1111111", "86-2222222" ], "addresses": { "address": "A省B市", "pc": "100001" }, "children": [ { "name": "张继", "age": "22", "sex": true, "M_TYPE": [ { "MACHINE_TYPE": 1, "MACHINE_NAME": "传统", "MACHINE": [ { "MACHINE_NO": "26088", "STATUS": 2, "BALANCE": 12.3 } ] }, { "MACHINE_TYPE": 2, "MACHINE_NAME": "竞彩", "MACHINE": [{ "MACHINE_NO": "26093", "STATUS": 1, "BALANCE": 100.22 } ] } ] }, { "name": "张承", "age": "11", "sex": false, "M_TYPE": [ { "MACHINE_TYPE": 3, "MACHINE_NAME": "传统", "MACHINE": [{"MACHINE_NO": "26038", "STATUS": 3, "BALANCE": 1300.5} ] } ] } ] }
<span style="font-family:Arial, Helvetica, sans-serif;"><span style="white-space: normal;"> </span></span>
相关文章推荐
- 3、利用SuperObject 循环处理Json深层次的值
- JSON利用superobject进行资料交换及重新封装ClientDataSet
- 【fastJSON】利用fastJSON处理循环引用的问题
- 利用Jackson对Object,Map,List,数组,枚举,日期类等转化为json
- 利用 Newtonsoft 处理Json 特殊字符
- JSON 之 SuperObject(9): TSuperType
- JSON 之 SuperObject(10): Merge、Clone、ForcePath
- JSON 之 SuperObject(6): 方法
- Newtonsoft.Json对object进行json转化(时间格式的处理)
- JSON 之 SuperObject(17): 实例 - 借用 Google 实现全文翻译
- 用 SuperObject 解析淘宝上的 Json 数据 - 回复 "macrolen" 的问题
- 利用 Java 6 直接处理 JSON
- JSON 之 SuperObject(1)
- android利用http请求json处理
- JSon SuperObject 研究2:数据集与JSON对象互转
- 利用异常处理循环……
- JSON 之 SuperObject(5): Format 与转义字符
- JSON 之 SuperObject(4): 增、删、改
- JSON 之 SuperObject(12): TSuperEnumerator、TSuperAvlIterator、ObjectFindFirst...
- JSON工具SuperObject编译时"整数溢出"异常的解决办法