首页 > 其他分享 >Delphi原生JSON框架(二)TJsonArray

Delphi原生JSON框架(二)TJsonArray

时间:2024-07-18 13:40:57浏览次数:6  
标签:ja Log jv Value GetValue JSON TJsonArray Delphi name

前面写了如何快速读取一个JSON串,但只是针对简单的类型,如果JSON串中有数组该怎么办呢?

一、例子代码

先看下面的代码,读取一个学生的各科成绩。

procedure TForm6.Button1Click(Sender: TObject);
var
  jsonstr:string;

  jv:TJSONValue;
  js:TJSONString;
  ja:TJSONArray;
  jo:TJSONObject;

  I: Integer;
begin
  jsonstr:=
            '{' +
            '    "person": {' +
            '        "sex": "男",' +
            '        "name": "王小二",' +
            '        "score": [{' +
            '                "语文": 120' +
            '            },' +
            '            {' +
            '                "数学": 89' +
            '            },' +
            '            {' +
            '                "英语": 100' +
            '            }' +
            '        ]' +
            '    }' +
            '}';

  jv := TJSONValue.ParseJSONValue(jsonstr); //将JSON串转换为JSON对象,即TJSONValue对象
  if jv <> nil then
  begin

    Log('姓名:' + jv.GetValue<TJSONValue>('person.name').Value); //直接读取节点值
    Log('性别:' + jv.GetValue<TJSONValue>('person.sex').Value);
    Log('成绩');

    if jv.TryGetValue<TJSONArray>('person.score', ja) then  //读取JSON对象中的数组对象
    begin
      for I := 0 to ja.Count - 1 do //循环数组对象
      begin
        jo := ja.A[I] as TJSONObject;  //取数组元素对象
        var pair:= jo.Pairs[0];        //取出Pair对象
        var s1 := pair.JsonString.value; //读取Pair中键名
        var s2 := pair.JsonValue.Value;  //读取Pair中值
        //var s2:=jo.Values[s1].Value; //也可以根据Pair的键名读取键值
        Log(s1 + '=' + s2);
      end;
    end;
    Log(jv.ToString);  //输出:{"person":{"sex":"男","name":"王小二","score":[{"语文":120},{"数学":89},{"英语":100}]}}
    log(jv.ToJSON);    //输出:{"person":{"sex":"\u7537","name":"\u738B\u5C0F\u4E8C","score":[{"\u8BED\u6587":120},{"\u6570\u5B66":89},{"\u82F1\u8BED":100}]}}
  end;

end;

运行后输出的结果:

二、代码解读

通过上面代码,重点在于如何解读JSON中的数组对象TJSONArray。

TJSONArray都是从TJSONValue继承而来,所以我们可以象正常一样,用TryGetValue方法从TJSONValue中读取一个TJSONArray对象。得到了TJSONArray对象,有两种方法取到每个元素值:

  • TJSONArray.A[X]
  • TJSONArray.Items[X]

这两种方式,都返回TJSONValue类型的对象。

循环一个TJSONArray,用到了TJSONArray.Count,即数据的长度,也可以用Size,但官方已经明确用Count取代了。从上面的代码中摘录出来:

if jv.TryGetValue<TJSONArray>('person.score', ja) then  //读取JSON对象中的数组对象
    begin
      for I := 0 to ja.Count - 1 do //循环数组对象
      begin
        jo := ja.A[I] as TJSONObject;    //取数组元素对象
        //jo := ja.Items[I] as TJSONObject;//取数组元素对象的另一种写法
        //...
      end;
    end;

循环一个TJSONArray的另一种写法,这种写法更简洁:

if jv.TryGetValue<TJSONArray>('person.score', ja) then  //读取JSON对象中的数组对象
    begin
      var jva:TJSONValue;
      for jva in ja do
      begin
        jo :=jva as TJSONObject;
        //...
      end;
    end;

我们可以快速读取一个数组的JSON串了,直接上代码:

procedure TForm6.Button2Click(Sender: TObject);
begin
var jsonstr:=
            '{' +
            '    "code": 0,' +
            '    "msg": "Success",' +
            '    "check": true,' +
            '    "datas": [{' +
            '            "id": 1,' +
            '            "name": "测试1",' +
            '            "age": 10' +
            '        },' +
            '        {' +
            '            "id": 2,' +
            '            "name": "测试2",' +
            '            "age": 10' +
            '        },' +
            '        {' +
            '            "id": 3,' +
            '            "name": "测试3",' +
            '            "age": 10' +
            '        },' +
            '        {' +
            '            "id": 4,' +
            '            "name": "测试4",' +
            '            "age": 10' +
            '        },' +
            '        {' +
            '            "id": 5,' +
            '            "name": "测试5",' +
            '            "age": 10' +
            '        }' +
            '    ],' +
            '    "time": "2020-12-03 11:19:08"' +
            '}';

  var jv := TJSONValue.ParseJSONValue(jsonstr);
  Log('code=' + jv.GetValue<TJSONValue>('code').Value);
  Log('msg=' + jv.GetValue<TJSONValue>('msg').Value);
  Log('check=' + jv.GetValue<TJSONBool>('check').Value);
  Log('time=' + jv.GetValue<TJSONValue>('time').Value);
  var ja := jv.GetValue<TJSONArray>('datas');
  var jva: TJSONValue;
  for jva in ja do
  begin
    Log('id=' + jva.GetValue<TJSONValue>('id').Value);
    Log('name=' + jva.GetValue<TJSONValue>('name').Value);
    Log('age=' + jva.GetValue<TJSONValue>('age').Value);
  end;

end;

输出结果:

通过上面的代码,其核心是基于TJSONValue及TJSONArray对象,就解析了这个JSON串!! 

如果我们将jva转换成一个TJSONObject对象,那么基于TJSONObject对象的GetValue方法,可以改写这样:

var ja := jv.GetValue<TJSONArray>('datas');
  var jva: TJSONValue;
  for jva in ja do
  begin
    var jo:=jva as TJSONObject;
    Log('id=' + jo.GetValue('id').Value);
    Log('name=' + jo.GetValue('name').Value);
    Log('age=' + jo.GetValue('age').Value);
  end;

 

标签:ja,Log,jv,Value,GetValue,JSON,TJsonArray,Delphi,name
From: https://www.cnblogs.com/sttchengfei/p/18309351

相关文章

  • Delphi原生JSON框架(一) TJsonValue
    Delphi自带了json支持,引用System.json,你就可以处理json,读写json格式的内容都是被支持的。发展了几个版本,无论性能及稳定性都已经成熟,我不喜欢引用更多的三方到项目中,所以,对于Delphi处理json来说,自带的是我的首选。目前,DelphiJson的实现,支持json所有的类型:TJSONObjectTJSONArra......
  • 第十三篇 Json模块
    JSON函数使用JSON函数需要导入json库:importjson。函数描述json.dumps将Python对象编码成JSON字符串json.loads将已编码的JSON字符串解码为Python对象json.dumpsjson.dumps用于将Python对象编码成JSON字符串。语法json.dumps(obj,skipkeys=False,en......
  • mysql json语法总结
    json字段定义和插入创建一个带有json字段的表createtabletest10( idintnotnullauto_incrementcomment'id', namevarchar(64)nulldefault""comment'name', json_datajsondefaultnullcomment"json格式数据", primarykey(id))插......
  • FastJson详解
    文章目录一、FastJson介绍二、FastJson序列化API1、序列化Java对象2、序列化List集合3、序列化Map集合三、FashJson反序列化API1、反序列化Java对象2、反序列化List集合3、反序列化Map集合(带泛型)四、SerializerFeature枚举1、默认字段为null的不显示2、格式化五、@JSo......
  • laravel11:发生异常时返回json
    一,未配置前laravel11直接render页面如图:二,配置1, bootstrap/app.php<?phpuseIlluminate\Http\Request;useIlluminate\Auth\AuthenticationException;useIlluminate\Database\Eloquent\ModelNotFoundException;useIlluminate\Foundation\Application;useIllu......
  • Fastjson的payload收集
    What无第三方依赖收集了网络上的多种payload,方便进行fuzz测试提供了自动替换payload的功能,一次性为所有payload插入rmi地址/dnslogHelp--list:以清单的形式打印,方便作为字典进行fuzz--address:服务器地址(无需rmi://前缀),如11.22.33.44/exp、eval.com/rce--dns:dnslog的地址,不同......
  • 在存储过程输入输出参数中使用json
    SqlServer从2016开始支持json操作,JSON支持适用于SqlServer2016及以上版本和AzureSQLDatabase。sqlserver文档参考这里。有了这个json支持,默认过程只传入一个json字符串参数就可以了,方便很多。我们可以在内部做很多事情。甚至可以校验参数,鉴权或将结果集封装为标准的......
  • 实时时钟、弱函数、json
    一、实时时钟时间戳(实时的时间【单位:s】):​ 使用"time.h"文件:​ mktime()——得到一个时间戳​ localtime() ——得到一个当前时间的结构体(包含:年-月-日时:分:秒)eg:time_ttimestamp=mktime(&utc_time);//得到一个时间戳(单位为秒)structtm*beijing_time=lo......
  • Java实现将json数据转换为sql insert语句
    Java实现将json数据转换为sqlinsert语句importcom.fasterxml.jackson.core.JsonProcessingException;importcom.fasterxml.jackson.databind.JsonNode;importcom.fasterxml.jackson.databind.ObjectMapper;importjava.util.Iterator;importjava.util.Map;publicclassJson......
  • C# 任意类型数据转JSON格式
    1publicclassObjectToJson2{3///<summary>4///List转成json5///</summary>6///<typeparamname="T"></typeparam>7///<paramname="jso......