当前位置: 首页 > 知识库问答 >
问题:

使用来自A值的数据作为新的键,将内容从HashMap A移动到HashMap B

楮法
2023-03-14

是否可以使用源映射中的数据使用另一个哈希映射的 KV 对填充哈希映射。例如,让我们假设我们有一张如下所示的地图:

Map<Position,Place> positionMap = new HashMap<Position,Place>();

现在考虑 Place 类同时包含字符串类别位置对象。

有没有可能使用一个循环,并使用place-object中的< code>category字符串作为新HashMap的键,将Place对象从positionMap转移到categoryMap中,该HashMap的值将是Places集合?所以一个集合包含A类的所有位置,另一个包含b类的位置。

Map<String,Set<Place>> categoryMap = new HashMap<String,Set<Place>>();

共有1个答案

白禄
2023-03-14

您需要groupingBy操作:

Map<String,Set<Place>> categoryMap = positionMap().values().stream()
      .collect(Collectors.groupingBy(Place::getCategory, Collectors.toSet()));

但是,您希望收集到<代码>集

 类似资料:
  • 我有一个ViewModel,我正在使用LiveData,所以我有一个返回LiveData>的DAO,我可以让它工作,但实际上我希望它首先显示来自Room数据库的数据(如果有的话),然后当webservice返回新数据(如果有的话)时,将其写入数据库,然后用数据库中的最新数据更新ViewModel。我首先从数据库返回数据,并在后台将新数据写入数据库,但如何让ViewModel再次使用数据库中的新数据

  • 我有一个csv文件,它有一个值为1或2的列exch。另一列中有许多数字。问题是我想要EXCH2数据紧挨着EXCH1数据。是否有一种方法可以将EXCH2数据从与EXCH1数据相同的列中移除,使其成为自己的新列,并重置索引,使它们并排在一起? 电流输出:

  • 我正试着在一个熊猫数据目录中加载一个SQLAlchemy。 当我尝试: 我得到一个属性错误: 和 上一个问题SQLAlchemy ORM到pandas DataFrame的转换解决了我的问题,但是解决方案:使用不是我的解决方案。我使用db.session.add()和db.session.commit()打开/关闭会话,但是当我使用时,就会得到一个属性错误:

  • 问题内容: 我将几个引用的表与整数主键一起使用。现在,我想将int更改为GUID,保留所有引用不变。最简单的方法是什么? 谢谢! 添加 我确实了解该过程,所以我需要更详细的建议,例如,如何填充新的GUID列。使用默认值newid()是正确的,但是对于已经存在的行呢? 问题答案: 在主表中为guid值创建一个新列。使用uniqueidentifier数据类型,并使其不为null,并使用newid()

  • 我有两个表,其中主键(另一个表上的外键)在运行时自动递增(使用TOAD for mysql)。如何使用事务将数据同时插入两个表中。 这是第一个表的ddl: 第二个表的ddl: 注意:主要的挑战是从主键上获取自动递增的键值,以便在运行时插入到另一个表中。 提前谢谢。

  • 问题内容: 我有两个Spark数据框: 数据框A: 和数据框B: 数据框B可以包含来自数据框A的重复行,更新行和新行。我想在spark中编写操作,在其中可以创建一个新数据框,其中包含数据框A的行以及数据框B的更新行和新行。 我首先创建一个仅包含不可更新列的哈希列。这是唯一的ID。所以我们可以说,并可以改变值(可更新),但是是唯一的。我创建了一个哈希函数为: 现在,我想编写一些火花代码,基本上从B中