- package com.common.main.mapAndList;
- imp
ort java.util.ArrayList; - imp
ort java.util.HashMap; - imp
ort java.util.Iterator; - imp
ort java.util.List; - imp
ort java.util.Map; - /**
- * @author LiJianShe
- * @version 創建時間:Mar 19, 2010 3:33:35 PM 類說明:Student.java
- */
- public class Student {
- private String classId;
- private String studentId; // 学号
- private String studentName; // 姓名
- private String sex; // 性別 0 男 1 女
- public String getClassId() {
- return classId;
- }
- public void setClassId(String classId) {
- this.classId = classId;
- }
- public String getSex() {
- return sex;
- }
- public void setSex(String sex) {
- this.sex = sex;
- }
- public String getStudentId() {
- return studentId;
- }
- public void setStudentId(String studentId) {
- this.studentId = studentId;
- }
- public String getStudentName() {
- return studentName;
- }
- public void setStudentName(String studentName) {
- this.studentName = studentName;
- }
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- List studentAllList = null ;// 所以班級的学生
- //步骤1
- Map<String ,List> map = new HashMap<String ,List>();
- Map<String ,Object> mapLast = new HashMap<String ,Object>();
- // for(Student student : studentAllList){
- for(Iterator it = studentAllList.iterator();it.hasNext();){
- Student student = (Student)it.next();
- if(map.containsKey(student.getClassId())){ //如果已经存在这个数组,就放在这里
- List studentList = map.get(student.getClassId());
- studentList.add(student);
- }else{
- List studentList = new ArrayList(); //重新声明一个数组list
- studentList.add(student);
- map.put(student.getClassId(), studentList);
- }
- }
- // 步骤2
- // 利用 处理1 步骤 分组完的数据 ,按性别 男/女 再次分组
- for(Map.Entry<String, List> m: map.entrySet()){ //按键值遍历 Map
- Map mapList = new HashMap(); //
- List studentSingle = m.getValue(); //同一班级的学生,男女
- List studentListMen = new ArrayList(); // 声明一个存放男生的 list
- List studentListWomen = new ArrayList(); // 声明一个存放女生的 list
- for(Iterator it = studentSingle .iterator();it.hasNext();){//遍历
- Student student = (Student)it.next();
- if("0".equals(student.getSex())){ //男生
- studentListMen.add(student); //男生
- }else{
- studentListWomen.add(student); //女生
- }
- }
- mapLast.put("班级", m.getKey());
- mapLast.put("学生 男", studentListMen);
- }
- }
- }
在一些应用中,需要将List中的对象按某种情况分组或者排序处理。做个小结如下:
1. 如一个List中存放了ProductDoing对象,productDoing对象有rawTypeId 现在要求将rawTypeId分组处理。
先用Map找出list中所有的分组:
//原料类型组
Map<Integer,String> groups = new HashMap<Integer,String>();
for(ProductDoingVo pd : products){
groups.put(pd.getRawTypeId(),"");//这里并没有将该组的数据存入,看自己的需求吧
}
接下来就可以对已知的分组处理。
for(Integer rawTypeId : groups.keySet()){
for(ProductDoingVo pd : products){
if(rawTypeId.equals(pd.getRawTypeId())){
//处理该组的数据
}
}
}
2. 如2个List中存放了map<String,String>对象, 一个map是一个条数据库表记录,key是数据库表中的字段名,value是字段对应的值, map中操作时间的key_value, 需要将这2个List合并之后按map中的操作时间去排个序。。。。
//先用addAll将list连接起来,合成一个List
List result = new ArrayList();
Collections.addAll(result, a);//假设a b即为那两个list
Collections.addAll(result, b);
//实现一个Comparator就好了,根据map中的操作时间来排序
Collections.sort(result, new Comparator<Map>()
{
public int compare(Map o1, Map o2) {
Date date1 = (Date)o1.get("trackdatetime");
Date date2 = (Date)o2.get("trackdatetime");
return date1.compareTo(date2);
}
});
1. 如一个List中存放了ProductDoing对象,productDoing对象有rawTypeId 现在要求将rawTypeId分组处理。
先用Map找出list中所有的分组:
//原料类型组
Map<Integer,String> groups = new HashMap<Integer,String>();
for(ProductDoingVo pd : products){
groups.put(pd.getRawTypeId(),"");//这里并没有将该组的数据存入,看自己的需求吧
}
接下来就可以对已知的分组处理。
for(Integer rawTypeId : groups.keySet()){
for(ProductDoingVo pd : products){
if(rawTypeId.equals(pd.getRawTypeId())){
//处理该组的数据
}
}
}
2. 如2个List中存放了map<String,String>对象, 一个map是一个条数据库表记录,key是数据库表中的字段名,value是字段对应的值, map中操作时间的key_value, 需要将这2个List合并之后按map中的操作时间去排个序。。。。
//先用addAll将list连接起来,合成一个List
List result = new ArrayList();
Collections.addAll(result, a);//假设a b即为那两个list
Collections.addAll(result, b);
//实现一个Comparator就好了,根据map中的操作时间来排序
Collections.sort(result, new Comparator<Map>()
{
public int compare(Map o1, Map o2) {
Date date1 = (Date)o1.get("trackdatetime");
Date date2 = (Date)o2.get("trackdatetime");
return date1.compareTo(date2);
}
});