2016-10-12 224 views
0

我有一个JSON格式的字符串。我需要使用属性对这个JSON字符串进行排序,但无法做到这一点。 JSON字符串是通过读取CSV文件创建的。我不想再读取CSV,只能使用JSON字符串来实现它。有没有办法做到这一点?请告诉我。Java:使用键排序JSON字符串

JSON字符串格式为:

[ 
    { 
    "address": "some address", 
    "name": "some name", 
    "phone": "some phone", 
    "age": "some age", 
    "SSN": "some SSN" 
    }, 
    { 
    "address": "abc", 
    "name": "def", 
    "phone": "ghi", 
    "age": "jkl", 
    "SSN": "mno" 
    } 
] 

请解释。

+0

您的意思是“使用属性对此JSON字符串进行排序”。按地址按字母顺序排列上述条目? – hammerfest

回答

0

您可以将JSONstring转换为一个TreeMap,并使用您实现的Comparator按值进行比较,然后将此TreeMap转换回JSON。

了解如何在这里创建一个价值比较: http://www.programcreek.com/2013/03/java-sort-map-by-value/

然后用ObjectMapper到JSON转换成地图的地图回JSON:

String json = "{\"address\" : \"def\"," 
    + "\"name\" : \"ghi\"," 
    + "\"phone\" : \"jkl\"," 
    + "\"age\" : \"def\"," 
    + "\"SSN\" : \"abc\"}"; 

Map<String, String> jsonMap = new HashMap<String, String>(); 
ObjectMapper mapper = new ObjectMapper(); 
jsonMap = (mapper.readValue(json, Map.class)); 
Comparator<String> comparator = new ValueComparator(jsonMap); 
Map<String, String> treeMap = new TreeMap<String, String>(comparator); 
treeMap.putAll(jsonMap); 
String sortedJson = mapper.writeValueAsString(treeMap); 

System.out.println(sortedJson); 

结果: {“SSN “:” ABC”, “地址”: “高清”, “名”: “GHI”, “手机”: “JKL”}

比较:

public class ValueComparator implements Comparator<String> { 

    Map<String, String> map = new HashMap<String, String>(); 

    public ValueComparator(Map<String, String> map){ 
    this.map = map; 
    } 

    @Override 
    public int compare(String s1, String s2) { 
    return map.get(s1).compareTo(map.get(s2)); 
    } 
}