我有一些要从服务器中提取的JSON数据。 此数据中的字段之一是距离值。 我需要按照ListView中从最低到最高的距离对数据进行排序。 我不确定该怎么做?

任何帮助表示赞赏。

这是我获取数据的代码,不确定如何正确排序?

// Hashmap for ListView

ArrayList> bathroomList = new ArrayList>();

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

requestWindowFeature(Window.FEATURE_CUSTOM_TITLE);

setContentView(R.layout.activity_search);

getWindow().setFeatureInt(Window.FEATURE_CUSTOM_TITLE, R.layout.window_title);

// Creating JSON Parser instance

JSONParser jParser = new JSONParser();

// getting JSON string from URL

JSONObject json = jParser.getJSONFromUrl(url);

try {

// Getting Array of Contacts

bathrooms = json.getJSONArray(TAG_BATHROOMS);

// looping through All Contacts

for(int i = 0; i < bathrooms.length(); i++){

JSONObject c = bathrooms.getJSONObject(i);

// Storing each json item in variable

String id = c.getString(TAG_ID);

String access = c.getString(TAG_ACCESS);

String city = c.getString(TAG_CITY);

String comment = c.getString(TAG_COMMENT);

String directions = c.getString(TAG_DIRECTIONS);

String name = c.getString(TAG_NAME);

String street = c.getString(TAG_STREET);

String bathroomtype = c.getString(TAG_BATHROOMTYPE);

String distance = c.getString(TAG_DISTANCE);

String distanceTrimmed = distance.substring(0,4) +"" +"miles away";

String avail = c.getString(TAG_AVAIL);

String country = c.getString(TAG_COUNTRY);

String state = c.getString(TAG_STATE);

String postal = c.getString(TAG_POSTAL);

//System.out.println(name);

// creating new HashMap

HashMap map = new HashMap();

// adding each child node to HashMap key => value

map.put(TAG_ID, id);

map.put(TAG_ACCESS, access);

map.put(TAG_CITY, city);

map.put(TAG_COMMENT, comment);

map.put(TAG_DIRECTIONS, directions);

map.put(TAG_NAME, name);

map.put(TAG_STREET, street);

map.put(TAG_BATHROOMTYPE, bathroomtype);

map.put(TAG_DISTANCE, distanceTrimmed);

map.put(TAG_AVAIL, avail);

map.put(TAG_COUNTRY, country);

map.put(TAG_STATE, state);

map.put(TAG_POSTAL, postal);

// adding HashList to ArrayList

bathroomList.add(map);

}

} catch (JSONException e) {

e.printStackTrace();

}

/**

* Updating parsed JSON data into ListView

* */

ListAdapter adapter = new SimpleAdapter(this, bathroomList,

R.layout.list_item,

new String[] { TAG_ID, TAG_NAME, TAG_STREET, TAG_CITY, TAG_STATE, TAG_POSTAL,TAG_COUNTRY, TAG_DISTANCE, TAG_DIRECTIONS, TAG_COMMENT, TAG_AVAIL, TAG_BATHROOMTYPE, TAG_ACCESS}, new int[] {

R.id.key,R.id.name, R.id.street, R.id.city, R.id.state, R.id.postal,R.id.country, R.id.distance, R.id.directions, R.id.comments, R.id.availability, R.id.bathroomtype, R.id.access });

setListAdapter(adapter);

调查使用自定义比较器:mkyong.com/java/

另外,Id建议仅为数据编写一个类,而不要使用Map。 我认为这并不是使用的正确结构。

我可以知道这里的浴室是什么。

使用Collections.sort()和自定义比较器对列表进行排序。

Collections.sort(bathroomList, new Comparator>()

{

@Override

public int compare(HashMap a, HashMap b)

{

return a.get(TAG_DISTANCE).compareTo(b.get(TAG_DISTANCE));

}

});

距离以字符串形式减小,但应使用其数值进行比较。 这段代码仍然有效吗?

否。为此,您需要将字符串解析为数字。 docs.oracle.com/javase/7/docs/api/java/lang/或docs.oracle.com/javase/7/docs/api/java/lang/。 正如@kcoppock所说,您实际上应该将数据存储在一个类中。 这样,您实际上可以存储正确键入的字段(而不仅仅是字符串)。 另外,您甚至可以使该类实现Comparable,然后就不需要自定义比较器了。

参见c2.com/cgi/wiki?StringlyTyped和codinghorror.com/blog/2012/07/new-programming-jargon.html。 顺便说一句,由于您使用的是JSON,因此我怀疑数据实际上不是以字符串形式而是以数字形式(在JSON中)传递的,并且您的代码解析得很差。

我的同样问题,但是感谢@rusmus,我现在可以正常使用。 看看在ListView上对双精度数据(距离)进行排序

试试这个代码:

Collections.sort(bathroomList, new Comparator>() {

@Override

public int compare(HashMap o1,

HashMap o2) {

return Double.compare(Double.parseDouble(o1.get(TAG_DISTANCE)), Double.parseDouble(o2.get(TAG_DISTANCE))); // error

}

});

android listview排序分组,Android:如何对ListView的数据进行排序?相关推荐

  1. android listview排序分组,Android:如何为ListView排序数据?

    我从服务器上下载了一些 JSON数据.该数据中的一个字段是距离值.我需要按ListView中从最低到最高的距离对数据进行排序.我不知道该怎么做呢? 任何帮助赞赏. 这是我的代码,以获取数据不确定如何正 ...

  2. android 好友字母分组,Android好友联系人按字母排序分组,自定义通讯录导航栏View...

    Android中仿微信实现联系人列表 按字母排序分组 自定义通讯录导航栏View,下边是效果图: 1. 自定义View public class SideBar extends View { // 触 ...

  3. mysql分组排列的查询语句_数据的排序与分组语句_MySQL

    bitsCN.com 数据的排序与分组语句 使用SQL语句执行查询操作时,我们可能发现查询出的数据结果的排序是无序的.为了更好的观察数据表中的查询结果,开发人员或者用户经常要对查询的数据进行排序操作, ...

  4. mysql索引排序算法_MySQL中利用索引对数据进行排序的基础教程

    MySQL中,有两种方式生成有序结果集:一是使用filesort,二是按索引顺序扫描.利用索引进行排序操作是非常快的,而且可以利用同一索引同时进行查找和排序操作.当索引的顺序与ORDER BY中的列顺 ...

  5. android危险权限分组,Android 6.0权限请求相关及权限分组方法

    Android M(6.0)API 23后加入了权限请求设置,APP需要使用某些权限需要主动申请. 权限分为3类,一组是Normal权限,无需申请,另一组是Dangerous,需申请,然后是特殊权限, ...

  6. android危险权限分组,Android 中的危险权限详细整理

    Android 中的危险权限详细整理 前言: Android 中有上百种权限,现在将所有的权限归为两类: 一类是普通权限 一类的危险权限 普通权限是指那些不会威胁到用户安全和隐私的权限,这部分权限系统 ...

  7. python数字排序分组代码_python pandas 组内排序、单组排序、标号的实例

    摘要:本文主要是讲解一下,如何进行排序.分为两种情况,不分组进行排序和组内进行排序.什么意思呢?具体来说,我举个栗子. ****注意**** 如果只是单纯想对某一列进行排序,而不进行打序号的话直接使用 ...

  8. python对字符串数组进行排序、依据字符数_Python进行数据的排序以及字符串的操作...

    数据异常值的过滤 在数据分析中,经常需要检测数据结构中的异常值.我们还是举个例子,先来创建一个包含三列的DataFrame对象,每一列都包含1000个随机数. 可以用describe( )函数查看每一 ...

  9. 人名和成绩一起排序_不同工作表中的数据表排序各异,如何用Excel数据透视表汇总?...

    用数据透视表做分析的时候,有时源数据有好几张数据表,且分布在不同的地方.且因为维护源数据的人不同,数据表的行.列标题也未必固定不变. 那么问题来了,如果各个数据表的行标题排序各不相同,如何将它们合并到 ...

最新文章

  1. pycharm第一个Python程序
  2. C++编程模拟生产者消费者模型
  3. 发那科冲压直线搬运机器人_行业应用 | 直线七轴软件配置
  4. 关于Lambda和匿名内部类
  5. 命令 / GDB / 多进程调试 + 多线程调试
  6. 【POJ - 1850】Code (组合数学,字符串另类排序)
  7. js (jQuery) 之 取值
  8. NLG ≠ 机器写作 | 专家专栏
  9. node csrf 防御 待续
  10. 在vue中实现锚点定位功能
  11. html+css基础-4-html标签、Doctype、iframe,table布局
  12. GNS3各种IOS下载
  13. 计算机打开查看方式默认是什么样,设置图片查看方式|两个设置图片默认打开方式方法...
  14. c#调用新浪微博开放平台接口
  15. linux 数据库 函数是什么,MySQL数据库函数(一)
  16. elasticsearch for windows
  17. 74HC02或非门仿真示例
  18. 建筑智能化资质办理要求
  19. Excel 使用技巧集锦——163种技巧
  20. 2021年腾讯云618活动最新优惠攻略

热门文章

  1. comtrade文件C语言,生成的comtrade.dat文件有关问题,波形分析软件打开看点是乱的...
  2. pta天梯赛 非常弹得球
  3. 浅谈智能座舱的“一芯多屏”
  4. Android投屏到电脑的软件
  5. 管理咨询的甲方和乙方(转)
  6. 如何准确测量身体各部位尺寸?
  7. 《深入理解Windows操作系统》笔记4
  8. 《地理信息系统导论》chapter 3 矢量数据模型 习作
  9. sunday算法特征码_实现 Sunday 算法
  10. adf的主要功能之一是_ADF