android listview排序分组,Android:如何对ListView的数据进行排序?
我有一些要从服务器中提取的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的数据进行排序?相关推荐
- android listview排序分组,Android:如何为ListView排序数据?
我从服务器上下载了一些 JSON数据.该数据中的一个字段是距离值.我需要按ListView中从最低到最高的距离对数据进行排序.我不知道该怎么做呢? 任何帮助赞赏. 这是我的代码,以获取数据不确定如何正 ...
- android 好友字母分组,Android好友联系人按字母排序分组,自定义通讯录导航栏View...
Android中仿微信实现联系人列表 按字母排序分组 自定义通讯录导航栏View,下边是效果图: 1. 自定义View public class SideBar extends View { // 触 ...
- mysql分组排列的查询语句_数据的排序与分组语句_MySQL
bitsCN.com 数据的排序与分组语句 使用SQL语句执行查询操作时,我们可能发现查询出的数据结果的排序是无序的.为了更好的观察数据表中的查询结果,开发人员或者用户经常要对查询的数据进行排序操作, ...
- mysql索引排序算法_MySQL中利用索引对数据进行排序的基础教程
MySQL中,有两种方式生成有序结果集:一是使用filesort,二是按索引顺序扫描.利用索引进行排序操作是非常快的,而且可以利用同一索引同时进行查找和排序操作.当索引的顺序与ORDER BY中的列顺 ...
- android危险权限分组,Android 6.0权限请求相关及权限分组方法
Android M(6.0)API 23后加入了权限请求设置,APP需要使用某些权限需要主动申请. 权限分为3类,一组是Normal权限,无需申请,另一组是Dangerous,需申请,然后是特殊权限, ...
- android危险权限分组,Android 中的危险权限详细整理
Android 中的危险权限详细整理 前言: Android 中有上百种权限,现在将所有的权限归为两类: 一类是普通权限 一类的危险权限 普通权限是指那些不会威胁到用户安全和隐私的权限,这部分权限系统 ...
- python数字排序分组代码_python pandas 组内排序、单组排序、标号的实例
摘要:本文主要是讲解一下,如何进行排序.分为两种情况,不分组进行排序和组内进行排序.什么意思呢?具体来说,我举个栗子. ****注意**** 如果只是单纯想对某一列进行排序,而不进行打序号的话直接使用 ...
- python对字符串数组进行排序、依据字符数_Python进行数据的排序以及字符串的操作...
数据异常值的过滤 在数据分析中,经常需要检测数据结构中的异常值.我们还是举个例子,先来创建一个包含三列的DataFrame对象,每一列都包含1000个随机数. 可以用describe( )函数查看每一 ...
- 人名和成绩一起排序_不同工作表中的数据表排序各异,如何用Excel数据透视表汇总?...
用数据透视表做分析的时候,有时源数据有好几张数据表,且分布在不同的地方.且因为维护源数据的人不同,数据表的行.列标题也未必固定不变. 那么问题来了,如果各个数据表的行标题排序各不相同,如何将它们合并到 ...
最新文章
- pycharm第一个Python程序
- C++编程模拟生产者消费者模型
- 发那科冲压直线搬运机器人_行业应用 | 直线七轴软件配置
- 关于Lambda和匿名内部类
- 命令 / GDB / 多进程调试 + 多线程调试
- 【POJ - 1850】Code (组合数学,字符串另类排序)
- js (jQuery) 之 取值
- NLG ≠ 机器写作 | 专家专栏
- node csrf 防御 待续
- 在vue中实现锚点定位功能
- html+css基础-4-html标签、Doctype、iframe,table布局
- GNS3各种IOS下载
- 计算机打开查看方式默认是什么样,设置图片查看方式|两个设置图片默认打开方式方法...
- c#调用新浪微博开放平台接口
- linux 数据库 函数是什么,MySQL数据库函数(一)
- elasticsearch for windows
- 74HC02或非门仿真示例
- 建筑智能化资质办理要求
- Excel 使用技巧集锦——163种技巧
- 2021年腾讯云618活动最新优惠攻略