1. 首页 > 科技

pandas数据转换嵌套多层json?(layui.table 里面 data 的json数据有多层嵌套,请问要怎么获取数据)

pandas数据转换嵌套多层json?(layui.table 里面 data 的json数据有多层嵌套,请问要怎么获取数据)

layui.table 里面 data 的json数据有多层嵌套,请问要怎么获取数据

JSONArray json = JSONArray.fromObject(models); //list集合数据转json

response.getWriter().println(json);//传到前台

//ajax

success: function(data){

var models = eval("("+data+")");

var rows="";

for(var i in models){

rows =rows + "<tr>"+

"<td>"+models[i].statDate+"</td>"+

"<td>"+models[i].endDate+"</td>"+

"<td>"+models[i].name+"</td>"+

"</tr>" ;

}

$("#show_table").append(rows);//添加到table

PS:这是Servlet的写法

在Python中怎么将json获取的数据如何转化为dataframe

dataframe是神马?

我只会json格式的数据转dict类型

import json

j = json.loads('{"name":"123","Age":22}') 

print(j) ========

你是指pandas里的dataframe吗?

传入dict参数实例化一下就行了

关于多层嵌套的json

在 2.0中提取这样的json

{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}

引用命名空间

using Newtonsoft.Json;

using Newtonsoft.Json.Linq;

可以把上面的JSON看成一个对象.你只要写对应的类即可

public class UserInfo

{

public string name;

public int age;

public address addr;

}

public class address

{

public string city;

public string province;

}

然后在解析的地方这样写:

string jsonData="{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":guangzhou,\"province\":guangdong}}";

UserInfo user=(UserInfo)JsonConvert.DeserializeObject(jsonData, typeof(UserInfo));

得到City的值只要:user.addr.City;

这样实现也行

JObject jsonObj = JObject.Parse(jsonData);

string name=jsonObj ["name"].ToString();

string age=jsonObj ["age"].ToString();

string city=((JObject )jsonObj ["addr"])["city"].ToString();

string province=((JObject )jsonObj ["addr"])["province"].ToString();

如何这个json是动态的呢?譬如让你输入一个json,如{"name":"lily","age":23,"addr":{"city":guangzhou,"province":guangdong}}; 然后让你输入一个对象,如city,然后系统会输出guangzhou这个值,那这样的话,json就是动态生成的了,我想了解有没有读取这样的json的方法。(注意,json是多级嵌套的。)

就用遍历

public string GetJsonValue(JEnumerable<JToken> jToken,string key)

{

IEnumerator enumerator = jToken.GetEnumerator();

while (enumerator.MoveNext())

{

JToken jc = (JToken)enumerator.Current;

if (jc is JObject||((JProperty)jc).Value is JObject)

{

return GetJsonValue(jc.Children(), key);

}

else

{

if (((JProperty)jc).Name == key)

{

return ((JProperty)jc).Value.ToString();

}

}

}

return null;

}

在调用的时候:

string jsonData = "{\"name\":\"lily\",\"age\":23,\"addr\":{\"city\":\"guangzhou\",\"province\":\"guangdong\"}}";

JObject jsonObj = JObject.Parse(jsonData);

Response.Write(GetJsonValue(jsonObj.Children(), "province"));

如果有多层嵌套的数组

string jsonData = "{\"addr\":[{\"city\":\"guangzhou\",\"province\":\"guangdong\"},{\"city\":\"guiyang\",\"province\":\"guizhou\"}]}";

JObject jsonObj = JObject.Parse(jsonData);

JArray jar = JArray.Parse(jsonObj["addr"].ToString());

JObject j = JObject.Parse(jar[0].ToString());

Response.Write(j["city"]);

JSON转XML

string xmlstr=((XmlDocument)JsonConvert.DeserializeXmlNode(jsonData)).InnerXml.ToString();

json多层集合嵌套解析求助

{}是object []是array 一层一层解析的话,{}对应jsonobject,[]对应jsonarray