![](/img/trans.png)
[英]Extract json string array value from json object using java
[英]Extract value using JSON Path from array
我在下面有Json
{"pd":"{\"e\":{\"h\":{\"ak\":\"120\",\"at\":\"app\"},\"b\":[{\"ts\":1319549658547,\"tz\":-400,\"s\":\"StartUpScreen\",\"et\":8,\"ev\":\"sessionStart\",\"si\":\"19477682-de55-414f-82c9-19bec331dc33\",\"tt\":{\"day\":\"Tuesday\"}},{\"ts\":132,\"tz\":-400,\"s\":\"StartUpScreen\",\"et\":3,\"ev\":\"AutomaticFeedRefresh\",\"si\":\"19477682-de55-414f-82c9-19bec331dc33\",\"tt\":{}},{\"ts\":131,\"tz\":-400,\"s\":\"MainScreen\",\"et\":3,\"ev\":\"MainScreen Event\",\"si\":\"19477682-de55-414f-82c9-19bec331dc33\",\"tt\":{}}],\"tt\":{\"OSV\":\"7.10\"}}}","serverPayload":{"httpHeaders":{"x-bluecoat-via":["35D3468EFF4D5F18"],"content-type":["application\/x-www-form-urlencoded"]},"senderIp":["101.100.000.100"]}}
我只需要ak
, b [ts,si and tt[day]]
和senderIp
。 现在我有2个问题,如何在'b'和'senderIp'中提取所有'ts'属性。 我已经使用下面的代码为ak,ts和si。 我不知道如何得到'tt',同时我运行此代码时会得到如下的异常
String pd = JsonPath.read(jsonString, "$.pd");
String ak = JsonPath.read(pd, "$e.h.ak");
String ak = JsonPath.read(pd, "$e.h.b[0]");
// String b = JsonPath.read(pd,"$.e.b[0][0]");
// String b = JsonPath.read(pd,"$.e.b[0][5]");
System.out.println("value of ak: "+ak);
线程“main”中的异常java.lang.ClassCastException: net.minidev.json.JSONObject cannot be cast to java.lang.String
。
$.ehb[0]
看起来像一个JavaScript对象(包含“ts”和“tz”的字段),而不是字符串。 因此,您的JSON解析器将其视为JSONObject而不是字符串是合理的。 可能你需要深入到$.ehb[0].ts
或你感兴趣的任何领域。这样的东西:
long ts = JsonPath.read(pd, "$e.h.b[0].ts");
我假设它是你的第二个String ak =
line导致异常。 我无法理解你关于“ts”属性的其他问题。 也许您可以格式化JSON字符串以便于阅读?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.