问题描述
嗨,如果有人回答,感谢您的支持:
我有一个从 MysqL 查询中获取的列表,它返回列表中的几个元素。我在 Flutter 中收到这样的消息:
[0]:ListaTotPaises
gravedad:"3"
pais:"Colombia"
total:"1"
[1]:ListaTotPaises
gravedad:"2"
pais:"Colombia"
total:"1"
[2]:ListaTotPaises
gravedad:"2"
pais:"Spain"
total:"2"
我想从这个列表中得到不同的“pais”。在这种情况下,我想使用值“哥伦比亚”和“西班牙”,而不是两次哥伦比亚。
解决方法
您可以使用 map
获取所有 pais
,然后调用 toSet
删除重复项,最后调用 toList
。
myList.map((e) => e.pais).toSet().toList();
您也可以使用 map
+ contains
+ forEach
方法来解决这个问题:
final allPais = myList.map((e) => e.pais);
final distinctPais = [];
allPais.forEach((e) {
if (!distinctPais.contains(e)) {
distinctPais.add(e);
}
});
,
另一个使用 retainWhere
final sets = Set();
myList.retainWhere((e) => sets.add(e.pais));