簡體   English   中英

排序ArrayList <HashMap<String, String> &gt;使用價值

[英]sort ArrayList<HashMap<String, String>> using value

我的代碼中有Hashmap的ArrayList,我很困惑應該使用哪種排序方法? 我的代碼如下

arraylist = new ArrayList<HashMap<String, String>>();
            // Retrieve JSON Objects from the given URL address
            jsonobject = JSONFunctions
                        .getJSONfromURL("https://api.foursquare.com/v2/venues/search?    client_id=ACAO2JPKM1MXHQJCK45IIFKRFR2ZVL0QASMCBCG5NPJQWF2G&client_secret=YZCKUYJ1W    HUV2QICBXUBEILZI1DMPUIDP5SHV043O04FKBHL&v=20130815&ll=-34.678,138.87&radius=5000&section=coffee");

        try {
            // Locate the array name in JSON
            jsonarray = jsonobject.getJSONObject("response");

            JSONArray jsonSubarray = jsonarray.getJSONArray("venues");
            Log.v("Response Array", String.valueOf(jsonSubarray));



            for (int i = 0; i < jsonSubarray.length(); i++) {
                HashMap<String, String> map = new HashMap<String, String>();

                jsonobject = jsonSubarray.getJSONObject(i);
                // Retrive JSON Objects
                // Retrive JSON Objects

                Log.v("Store name", jsonobject.getString("name"));
                map.put("storeName", jsonobject.getString("name"));

                JSONObject locationObject = jsonobject.getJSONObject("location");
                Log.v("if condition",String.valueOf( locationObject.has("city")));
                if(locationObject.has("city"))
                {
                    map.put("city", locationObject.getString("city"));
                }
                else
                    map.put("city","N/A");

                double km = Double.valueOf(locationObject.getString("distance")) / 1000 ;
                Log.v("distance", String.valueOf(km));
                map.put("distance", String.valueOf(km));

                arraylist.add(map);

            }
        } catch (JSONException e) {
            Log.e("Error", e.getMessage());
            e.printStackTrace();
        }
        return null;
    }

這是我的JSON數據格式

"id": "4e321829d4c00077f657b8ec",
            "name": "TeAro Estate Wines",
            "contact": {},
            "location": {
                "lat": -34.670859098532766,
                "lng": 138.89067804714347,
                "distance": 2053,
                "cc": "AU",
                "city": "Williamstown",
                "state": "SA",
                "country": "Australia",
                "formattedAddress": [
                    "Williamstown SA",
                    "Australia"
                ]
            },
            "categories": [
                {
                    "id": "4bf58dd8d48988d14b941735",
                    "name": "Winery",
                    "pluralName": "Wineries",
                    "shortName": "Winery",
                    "icon": {
                        "prefix": "https://ss3.4sqi.net/img/categories_v2/food/winery_",
                        "suffix": ".png"
                    },
                    "primary": true
                }
            ],
        {
            "id": "4c454825f0bdd13a65c9cacc",
            "name": "Barossa Dam",
            "contact": {},
            "location": {
                "address": "Dam it",
                "lat": -34.645353,
                "lng": 138.848115,
                "distance": 4150,
                "cc": "AU",
                "city": "Sandy Creek",
                "state": "SA",
                "country": "Australia",
                "formattedAddress": [
                    "Dam it",
                    "Sandy Creek SA",
                    "Australia"
                ]
            },

我想按距離對它進行排序,請給我一些建議,告訴我應該使用哪種方法,我對哈希映射的數組列表和數組列表感到困惑,如何使用collection.sort對數據進行排序。

我想根據ArrayList中的值進行排序。

使用比較器對其進行排序。

Comparator<HashMap<String, String>> distanceComparator = new Comparator<HashMap<String,String>>() {

    @Override
    public int compare(HashMap<String, String> o1, HashMap<String, String> o2) {
        // Get the distance and compare the distance.
        Integer distance1 = Integer.parseInt(o1.get("distance"));
        Integer distance2 = Integer.parseInt(o2.get("distance"));

        return distance1.compareTo(distance2);
    }
};

// And then sort it using collections.sort().
Collections.sort(arrayList, distanceComparator);
Collections.sort(arrayList, (HashMap<String, String> m1, HashMap<String, String> m2) -> 
            Integer.parseInt(m1.get("distance").compareTo(Integer.parseInt(m2.get("distance")))));

使用Java 1.8和Lambda表達式功能更簡潔。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM