我有一个json数组怎么获取某个字段的对应的对象
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了我有一个json数组怎么获取某个字段的对应的对象相关的知识,希望对你有一定的参考价值。
参考技术A public static void jsonToBean(String data)try
JSONArray array = new JSONArray(data);//将json字符串转成json数组
for (int i = 0; i < array.length(); i++) //循环json数组
JSONObject ob = (JSONObject) array.get(i);//得到json对象
String name= ob.getString("name");//name这里是列名称,获取json对象中列名为name的值
System.out.print(name);//输出name
catch (JSONException e)
本回答被提问者采纳
Java中对JSONArray中的对象的某个字段进行排序
需求:
今天调用一个第三方接口,然后返回的是一个josn数组,需要根据里面的“报告日期”报告日期进行由大到小排序,最新的排在前面。
这种别人接口已经开发完成,不能改,所以只有我们自己来排序。
思路一():将josn数组转为list集合,然后获取到里面的每个对象,再获取“报告日期”,然后排序,然后对对应的对象排序。
思路二:
实现java的Collections.sort方法,自定义Comparator方法,然后排序。
这样效率比较高。
下面是测试和实现代码。
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONException; import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.parser.deserializer.ParseProcess; /** * Java中对JSONArray中的对象的某个字段进行排序 * * @author lijianbo * @version 1.0 * */ public class Test1 implements ParseProcess { public static void main(String[] args) { String jsonArrStr = "[ { \"ID\": \"2016-05-25\", \"Name\": \"Fargo Chan\" },{ \"ID\": \"2016-05-23\", \"Name\": \"Aaron Luke\" },{ \"ID\": \"2016-05-26\", \"Name\": \"Dilip Singh\" }]"; System.out.println("排序前:"+jsonArrStr); String jsonArraySort = jsonArraySort(jsonArrStr); System.out.println("排序后:"+jsonArraySort); } /** * 按照JSONArray中的对象的某个字段进行排序(采用fastJson) * * @param jsonArrStr * json数组字符串 * */ public static String jsonArraySort(String jsonArrStr) { JSONArray jsonArr = JSON.parseArray(jsonArrStr); JSONArray sortedJsonArray = new JSONArray(); List<JSONObject> jsonValues = new ArrayList<JSONObject>(); for (int i = 0; i < jsonArr.size(); i++) { jsonValues.add(jsonArr.getJSONObject(i)); } Collections.sort(jsonValues, new Comparator<JSONObject>() { // You can change "Name" with "ID" if you want to sort by ID private static final String KEY_NAME = "ID"; @Override public int compare(JSONObject a, JSONObject b) { String valA = new String(); String valB = new String(); try { // 这里是a、b需要处理的业务,需要根据你的规则进行修改。 String aStr = a.getString(KEY_NAME); valA = aStr.replaceAll("-", ""); String bStr = b.getString(KEY_NAME); valB = bStr.replaceAll("-", ""); } catch (JSONException e) { // do something } return -valA.compareTo(valB); // if you want to change the sort order, simply use the following: // return -valA.compareTo(valB); } }); for (int i = 0; i < jsonArr.size(); i++) { sortedJsonArray.add(jsonValues.get(i)); } return sortedJsonArray.toString(); } }
结果为:
排序前:[ { "ID": "2016-05-25", "Name": "Fargo Chan" },{ "ID": "2016-05-23", "Name": "Aaron Luke" },{ "ID": "2016-05-26", "Name": "Dilip Singh" }] 排序后:[{"Name":"Dilip Singh","ID":"2016-05-26"},{"Name":"Fargo Chan","ID":"2016-05-25"},{"Name":"Aaron Luke","ID":"2016-05-23"}]
这个方法主要参考了这篇文章:
http://www.codes51.com/wd/582292.html
本文出自 “JianBo” 博客,请务必保留此出处http://jianboli.blog.51cto.com/12075002/1983017
以上是关于我有一个json数组怎么获取某个字段的对应的对象的主要内容,如果未能解决你的问题,请参考以下文章