java8 集合 多字段 分組 統(tǒng)計個數代碼
更新時間:2020年08月26日 09:43:31 作者:weixin_36754290
這篇文章主要介紹了java8 集合 多字段 分組 統(tǒng)計個數代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
1.user實體
package com.demo.dto;
public class User {
private Integer id;
private String userName;
private String password;
private Integer age;
private long c;
public User() {
super();
// TODO Auto-generated constructor stub
}
public User(Integer id, String userName, String password, Integer age) {
super();
this.id = id;
this.userName = userName;
this.password = password;
this.age = age;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName == null ? null : userName.trim();
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password == null ? null : password.trim();
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public long getC() {
return c;
}
public void setC(long l) {
this.c = l;
}
@Override
public String toString() {
return "User [id=" + id + ", userName=" + userName + ", password=" + password + ", age=" + age + ", c=" + c
+ "]";
}
public static void main(String[] args) {
User u1=new User(1, "aa", "aap", 23);
User u2=new User(2, "aa", "aap", 23);
User u3=new User(3, "bb", "aap", 23);
User u4=new User(4, "cc", "aap", 23);
User u5=new User(5, "cc", "aap", 23);
User u6=new User(6, "cc", "aap", 23);
User u7=new User(7, "aa", "aap", 24);
List<User> list=new ArrayList<User>();
list.add(u1);list.add(u2);list.add(u7);list.add(u3);list.add(u4);list.add(u5);list.add(u6);
//原有l(wèi)ist(根據第二個字段:userName和第四個字段:age 統(tǒng)計重復的記錄數)
//jdk8的方法統(tǒng)計個數:
Map<String, Map<Integer, Long>> map = list.stream().collect(Collectors.groupingBy(User::getUserName,Collectors.groupingBy(User::getAge,Collectors.counting())));
//jdk8以下:
Map<String,Map<Integer,Long>> map=new HashMap<String,Map<Integer,Long>>();
for (User user1 : list) {
Map<Integer, Long> value=new HashMap<Integer,Long>();
long count=0;
if(map.containsKey(user1.getUserName())){
continue;
}
for(int i=0;i<list.size();i++){
if(user1.getUserName().equals(list.get(i).getUserName())&&user1.getAge()==list.get(i).getAge()){
count+=1;
value.put(user1.getAge(),count);
map.put(user1.getUserName(), value);
}else if(user1.getUserName().equals(list.get(i).getUserName())&&user1.getAge()!=list.get(i).getAge()){
value.put(list.get(i).getAge(),Long.valueOf(1));
map.put(user1.getUserName(), value);
}
}
}
map.forEach((k, v) -> {
System.out.println(k+">>>>"+v);
});
List<User> list2=new ArrayList<User>();
list.forEach(user ->{
map.forEach((k, v) -> {
if(k==user.getUserName()){
Long remove = v.remove(user.getAge());
user.setC(null==remove?0:remove);
}
});
list2.add(user);
});
//遍歷最后想要的結果(User中c為統(tǒng)計后的個數,方便前臺遍歷集合時單元格合并行)
list2.forEach(u ->{
System.out.println(u);
});
}
}
備注:運行結果如下
cc>>>>{23=3}
bb>>>>{23=1}
aa>>>>{23=2, 24=1}
User [id=1, userName=aa, password=aap, age=23, c=2]
User [id=2, userName=aa, password=aap, age=23, c=0]
User [id=7, userName=aa, password=aap, age=24, c=1]
User [id=3, userName=bb, password=aap, age=23, c=1]
User [id=4, userName=cc, password=aap, age=23, c=3]
User [id=5, userName=cc, password=aap, age=23, c=0]
User [id=6, userName=cc, password=aap, age=23, c=0]
此處是為了實現如下效果:

補充知識:List集合中元素按照固定數量進行分組
最近做項目,被要求將全國所有省份在頁面中展示出來,但是要求
1、字少的三個省份占一行
2、字多的兩個省份占一行
想來想去只能想到查詢出所有省份,然后分組返回數據,上代碼
public Map<String,Object> campus_list_provence(HttpServletRequest request,HttpServletResponse response)throws Exception{
Map<String,Object> map=new HashMap<String,Object>();
String sql="查詢所有省份的名稱,可以先在數據庫中將全國所有省份建一個表";
List<String> list=bd.getSQLList(sql);
//創(chuàng)建第一個list1,里面存入省份名稱少于4個字的
List<String> list1=new ArrayList<String>();
//創(chuàng)建第二個list2,里面存入省份名稱大于4個字的
List<String> list2=new ArrayList<String>();
if(list!=null&&list.size()>0){
for (String string : list) {
if(string.length()>4){
list2.add(string);
}else{
list1.add(string);
}
}
}
int keyToken = 0;
int toIndex=3;
List<Object> listSortMap = new ArrayList<Object>();
for(int i = 0;i<list1.size();i+=3){
if(i+3>list1.size()){ //作用為toIndex最后沒有3條數據則剩余幾條newList中就裝幾條
toIndex=list1.size()-i;
}
List newList = list1.subList(i,i+toIndex);
keyToken++;
listSortMap.add(newList);
}
int keyToken2 = 0;
List<Object> listSortMap2 = new ArrayList<Object>();
for(int i = 0;i<list2.size();i+=2){
if(i+2>list2.size()){ //作用為toIndex最后沒有2條數據則剩余幾條newList中就裝幾條
toIndex=list2.size()-i;
}
List newList2 = list2.subList(i,i+toIndex);
keyToken2++;
listSortMap2.add(newList2);
}
map.put("prov1", listSortMap);
map.put("prov2", listSortMap2);
return map;
}
頁面接收
function campus_list_ByProvence(req_data){
$.ajax({
type : "POST",
url : "剛才方法的url",
traditional: true,
data : req_data,
timeout : 20000,
cache : false,
beforeSend : function(XMLHttpRequest) {},
success : function(data) {
/* 生成html */
$('#campus_list_provence').html(campus_list_ByProvenceHtml1(data.prov1,data.prov2));
},
error : function() { alert("ajax失敗!");}
});
}
function campus_list_ByProvenceHtml1(prov,prov2){
var html = "";
for(var i = 0 , j = prov.length ; i < j ; i++){
html+='<li class="li1" >';
if(prov[i][0]!=undefined&&prov[i][0]!=null&&prov[i][0]!=""){
var provstr0="'"+prov[i][0]+"'";
html+='<a href="#2" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="GoToUrlItem('+provstr0+');">'+prov[i][0]+'</a>';
}else{
html+='';
}
if(prov[i][1]!=undefined&&prov[i][1]!=null&&prov[i][1]!=""){
var provstr1="'"+prov[i][1]+"'";
html+='<a href="#2" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="GoToUrlItem('+provstr1+');">'+prov[i][1]+'</a>';
}else{
html+='';
}
if(prov[i][2]!=undefined&&prov[i][2]!=null&&prov[i][2]!=""){
var provstr2="'"+prov[i][2]+"'";
html+='<a href="#2" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="GoToUrlItem('+provstr2+');">'+prov[i][2]+'</a>';
}else{
html+='';
}
html+='</li>';
}
for(var i = 0 , j = prov2.length ; i < j ; i++){
html+='<li class="li2" >';
if(prov2[i][0]!=undefined&&prov2[i][0]!=null&&prov2[i][0]!=""){
var pro2vstr0="'"+prov2[i][0]+"'";
html+='<a href="#2" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="GoToUrlItem('+pro2vstr0+');">'+prov2[i][0]+'</a>';
}else{
html+='';
}
if(prov2[i][1]!=undefined&&prov2[i][1]!=null&&prov2[i][1]!=""){
var prov2str1="'"+prov2[i][1]+"'";
html+='<a href="#2" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" onclick="GoToUrlItem('+prov2str1+');">'+prov2[i][1]+'</a>';
}else{
html+='';
}
html+='</li>';
}
return html ;
}
感覺這樣寫好麻煩,不過最后還好弄出來了,如果有更好的方法請告訴我一下
頁面展示:

以上這篇java8 集合 多字段 分組 統(tǒng)計個數代碼就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
詳解Spring boot+CXF開發(fā)WebService Demo
這篇文章主要介紹了詳解Spring boot+CXF開發(fā)WebService Demo,非常具有實用價值,需要的朋友可以參考下2017-05-05
Spring Security動態(tài)權限的實現方法詳解
這篇文章主要和小伙伴們簡單介紹下 Spring Security 中的動態(tài)權限方案,以便于小伙伴們更好的理解 TienChin 項目中的權限方案,感興趣的可以了解一下2022-06-06

