对jsonarray中某个对象的某一个字段进行排序
2018-03-16 11:27
766 查看
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.JSONObject;
public class SortTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
String result="[{\"RANGE_area\": \"[0,15]\", \"city\": \"长沙市\", \"county\":\"天心区\",\"SUM_area\": 100,\"AVG_length\": 10 },"
+"{ \"RANGE_area\": \"(15,30]\", \"city\": \"长沙市\",\"county\":\"天心区\",\"SUM_area\": 200,\"AVG_length\": 10 },"
+"{ \"RANGE_area\": \"(30,60]\", \"city\": \"长沙市\", \"county\": \"天心区\",\"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{\"RANGE_area\":\"[0,15]\", \"city\": \"长沙市\", \"county\": \"开福区\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{\"RANGE_area\": \"(15,30]\", \"city\": \"长沙市\", \"county\": \"开福区\", \"SUM_area\": 500, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"[0,10]\", \"city\": \"衡阳市\", \"county\": \"衡阳县\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"(30,60]\", \"city\": \"衡阳市\", \"county\": \"衡阳县\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"(15,30]\", \"city\": \"衡阳市\", \"county\": \"祁东县\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"(30,60]\", \"city\": \"株洲市\", \"county\": \"醴陵市\", \"SUM_area\": 80, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"[0,10]\", \"city\": \"湘潭市\", \"county\": \"茶陵市\", \"SUM_area\": 200, \"AVG_length\": 10 },]";
JSONArray arr=JSON.parseArray(result);
JSONArray sortJsonarr=new JSONArray();
List<JSONObject> jsonValue=new ArrayList<JSONObject>();
for(int i=0;i<arr.size();i++){
jsonValue.add(arr.getJSONObject(i));
}
Collections.sort(jsonValue,new Comparator<JSONObject>() {
// private static final String key="city";
private static final String key="SUM_area";
public int compare(JSONObject a, JSONObject b) {
// String valA=a.getString(key);
// String valB=b.getString(key);
Integer valA=a.getIntValue(key);
Integer valB=b.getIntValue(key);
return valA.compareTo(valB);
}
});
for(int i=0;i<arr.size();i++){
sortJsonarr.add(jsonValue.get(i));
}
System.out.println(sortJsonarr.toJSONString());
}
}
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.JSONObject;
public class SortTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
String result="[{\"RANGE_area\": \"[0,15]\", \"city\": \"长沙市\", \"county\":\"天心区\",\"SUM_area\": 100,\"AVG_length\": 10 },"
+"{ \"RANGE_area\": \"(15,30]\", \"city\": \"长沙市\",\"county\":\"天心区\",\"SUM_area\": 200,\"AVG_length\": 10 },"
+"{ \"RANGE_area\": \"(30,60]\", \"city\": \"长沙市\", \"county\": \"天心区\",\"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{\"RANGE_area\":\"[0,15]\", \"city\": \"长沙市\", \"county\": \"开福区\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{\"RANGE_area\": \"(15,30]\", \"city\": \"长沙市\", \"county\": \"开福区\", \"SUM_area\": 500, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"[0,10]\", \"city\": \"衡阳市\", \"county\": \"衡阳县\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"(30,60]\", \"city\": \"衡阳市\", \"county\": \"衡阳县\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"(15,30]\", \"city\": \"衡阳市\", \"county\": \"祁东县\", \"SUM_area\": 200, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"(30,60]\", \"city\": \"株洲市\", \"county\": \"醴陵市\", \"SUM_area\": 80, \"AVG_length\": 10 },"
+ "{ \"RANGE_area\": \"[0,10]\", \"city\": \"湘潭市\", \"county\": \"茶陵市\", \"SUM_area\": 200, \"AVG_length\": 10 },]";
JSONArray arr=JSON.parseArray(result);
JSONArray sortJsonarr=new JSONArray();
List<JSONObject> jsonValue=new ArrayList<JSONObject>();
for(int i=0;i<arr.size();i++){
jsonValue.add(arr.getJSONObject(i));
}
Collections.sort(jsonValue,new Comparator<JSONObject>() {
// private static final String key="city";
private static final String key="SUM_area";
public int compare(JSONObject a, JSONObject b) {
// String valA=a.getString(key);
// String valB=b.getString(key);
Integer valA=a.getIntValue(key);
Integer valB=b.getIntValue(key);
return valA.compareTo(valB);
}
});
for(int i=0;i<arr.size();i++){
sortJsonarr.add(jsonValue.get(i));
}
System.out.println(sortJsonarr.toJSONString());
}
}
相关文章推荐
- 对jsonarray中某个对象的某一个字段进行排序
- Java中对JSONArray中的对象的某个字段进行排序
- 指定List对象中的某一字段进行排序
- jq按json数据某一字段进行排序
- web开发中如何对json对象的某一属性对其进行排序
- java list按照元素对象的指定多个字段属性进行排序
- 对LIST对象多个字段进行排序
- java 对象排序,根据多个字段进行排序
- Android List(集合)中的对象以某一个字段排序
- Flex对Array中的对象进行排序操作
- PHP中二维数组的排序、去除二维数组的重复、对二维数组的某一字段进行求和的方法
- List中的数据如何根据对象的某一个或多个字段排序
- java list按照元素对象的指定多个字段属性进行排序
- 根据对象的其中一个字段进行排序
- 根据对象中某一属性进行升序降序排序的javascript实现
- java对list里面的对象进行多字段排序(借鉴整理)
- Java按照List内存储的对象的某个字段进行排序的实例
- tree型的json数据按照json的某个字段对子节点进行排序
- 根据对象的某一属性进行排序的js代码(如:name,age)
- java针对list中的对象的某一属性进行排序