java 高效列转行,java 列转行「建议收藏」

java 高效列转行,java 列转行「建议收藏」一个员工在多个部门内,一个部门有多个员工List———–>Map>1.部门类publicclassDept{publicDept(Stringid){this.id=id;}privateStringid;//省略get,set方法}2.员工类publicclassUser{publicUser(Stringid)…

大家好,又见面了,我是你们的朋友全栈君。

一个员工在多个部门内,一个部门有多个员工

List ———–> Map>

1.部门类

public class Dept {

public Dept(String id) {

this.id = id;

}

private String id;

//省略get,set 方法

}

2.员工类

public class User {

public User(String id) {

this.id = id;

}

private String id;

private List deptList;

//省略get,set 方法

}

3: 测试类

public class TestDemo {

public static void main(String[] args) {

User user1 = new User(“员工1”);

User user2 = new User(“员工2”);

User user3 = new User(“员工3”);

Dept dept1 = new Dept(“部门1”);

Dept dept2 = new Dept(“部门2”);

ArrayList deptList = new ArrayList<>();

deptList.add(dept2);

deptList.add(dept1);

// 员工1 = 部门1,2

user1.setDeptList(deptList);

// 员工2 = 部门1

user2.setDeptList(Collections.singletonList(dept1));

// 员工3 = 部门1,2

user3.setDeptList(deptList);

ArrayList userList = new ArrayList<>();

userList.add(user3);

userList.add(user2);

userList.add(user1);

/* 转换成部门map应该为

* 部门1 = 员工1,2,3

* 部门2 = 员工1,3

*/

}

}

4.1我的实现:

先建一个组合类

public class UserComposite {

public UserComposite(User user, String deptId) {

this.user = user;

this.deptId = deptId;

}

private User user;

private String deptId;

//省略 get,set 方法

}

4.2: 实现代码

Map> map = userList.stream()

// 过滤空部门的数据

.filter(user -> user.getDeptList() != null && !user.getDeptList().isEmpty())

// 转换部门和员工的关系

.map(user-> user.getDeptList().stream().map(dept-> new UserComposite(user, dept.getId())).collect(Collectors.toList()))

// 合并流进行分组

.flatMap(List::stream).collect(Collectors.groupingBy(UserComposite::getDeptId, Collectors.mapping(UserComposite::getUser, Collectors.toList())));

System.out.println(map);

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148981.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 电容器图片及型号图片_电容电阻图片大全

    电容器图片及型号图片_电容电阻图片大全图1是胆电容;图2是灯具电容器;图3是MKPH电容;图4是MET电容;图5、图10是PEI电容;图6是胆贴片电容;图7是MPE电容;图8是贴片电容;图11是轴向电解电容器;图12是MPP电容。图1是PPN电容;图2是PET电容;图3是MEA电容;图4MPB是电容;图5是PPT电容;图6是MPT电容;图7是电解电容器;图8是MET电容;图9是MKPH电容;图10、11是电机用电容;图12是MKS电…

    2022年8月22日
    6
  • 数据库设计工具的使用(实用)

    数据库设计工具的使用(实用)使用数据库设计工具,以下sql语句全部可以自动生成:/*==============================================================*//*DBMSname:MySQL5.0*//*Createdon:2017/5/270:57:18

    2022年7月11日
    15
  • linux系统抓包工具_kali 抓包

    linux系统抓包工具_kali 抓包在使用ECS服务器时,发现网络流量异常,或者发现服务器有异常向外发包行为,可使用抓包工具抓取网络流量包,分析流量包的特征,看看这些流量包来自哪里,或者发向哪里了。根据这些信息,可进一步诊断异常。本文介绍Linux系统,使用tcpdump工具分析流量的方法。TcpDump可将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、not、or等逻…

    2022年8月21日
    3
  • 4月20日

    4月20日

    2021年9月27日
    47
  • 缓存雪崩和缓存穿透解决方案

    缓存雪崩和缓存穿透解决方案

    2021年7月10日
    62
  • Pytest(17)运行未提交的git(pytest-picked)

    Pytest(17)运行未提交的git(pytest-picked)前言我们每天写完自动化用例后都会提交到git仓库,随着用例的增多,为了保证仓库代码的干净,当有用例新增的时候,我们希望只运行新增的未提交git仓库的用例。pytest-picked插件可以

    2022年7月31日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号