需求:
今天调用一个第三方接口,然后返回的是一个josn数组,需要根据里面的“报告日期”报告日期进行由大到小排序,最新的排在前面。
这种别人接口已经开发完成,不能改,所以只有我们自己来排序。
思路一():将josn数组转为list集合,然后获取到里面的每个对象,再获取“报告日期”,然后排序,然后对对应的对象排序。
思路二:
实现java的Collections.sort方法,自定义Comparator方法,然后排序。
这样效率比较高。
下面是测试和实现代码。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
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();
}
}
|
结果为:
1
2
|
排序前:[ {
"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
本文转自建波李 51CTO博客,原文链接:http://blog.51cto.com/jianboli/1983017,如需转载请自行联系原作者