完成集合工具去重方法

This commit is contained in:
彭宇琦 2021-02-20 14:57:15 +08:00
parent 3ab7589976
commit 9460e51cea
2 changed files with 85 additions and 9 deletions

View File

@ -2,6 +2,7 @@ package com.auxiliary.tool.data;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.List;
import java.util.Map;
import java.util.Optional;
@ -20,7 +21,7 @@ import java.util.stream.Collectors;
* <b>编码时间</b>2020年12月22日上午8:27:07
* </p>
* <p>
* <b>修改时间</b>2020年12月22日上午8:27:07
* <b>修改时间</b>2021年2月20日上午7:20:37
* </p>
*
* @author 彭宇琦
@ -145,10 +146,10 @@ public class ListUtil {
/**
* 用于对列表中的数据类型进行转换返回新数据类型的列表
*
* @param <T> 原数据类型
* @param <U> 新数据类型
* @param <T> 原数据类型
* @param <U> 新数据类型
* @param tableData 原数据类型表
* @param mapper 数据转换方式
* @param mapper 数据转换方式
* @return 转换后的数据类型表
*/
public static <T, U> TableData<U> changeTable(TableData<T> tableData, Function<T, U> mapper) {
@ -156,6 +157,76 @@ public class ListUtil {
tableData.columnForEach((key, value) -> newTable.addColumn(key, changeList(value, mapper).stream()
.map(dataOptional -> dataOptional.orElse(null)).collect(Collectors.toList())));
return newTable;
}
/**
* 用于对集合中的元素进行去重
* <p>
* <b>注意</b>被比较的泛型对象去重按照equals()方法进行比较需要正确实现equals()方法才能达到去重的目的
* </p>
*
* @param <T> 需要去重的数据类型
* @param list 需要去重的集合
* @return 去重后的集合
*/
public static <T> List<Optional<T>> removeRepetition(List<Optional<T>> list) {
LinkedHashSet<Optional<T>> set = new LinkedHashSet<>();
Optional.ofNullable(list).filter(l -> !l.isEmpty()).ifPresent(l -> l.forEach(set::add));
return new ArrayList<Optional<T>>(set);
}
/**
* 用于根据指定的条件行对表中的数据进行去重
* <p>
* 方法需要指定列名表示以指定的列为基准对数据进行去重类似于数据库中指定字段为主键或联合主键
* 当指定的列的数据重复时将舍弃该数据所在行的整行数据达到去重的目的
* </p>
* <p>
* <b>注意</b>
* <ol>
* <li>被比较的泛型对象去重按照equals()方法进行比较需要正确实现equals()方法</li>
* <li>被舍弃的数据不区分其他内容只保留第一次存储的数据</li>
* </ol>
* </p>
*
* @param <T> 需要去重的数据类型
* @param tableData 需要去重的表
* @param columns 作为条件的列名称
* @return 去重后的表
*/
public static <T> TableData<T> removeRepetition(TableData<T> tableData, String... columns) {
//若传入的条件为空则直接返回传入的tableData
if (!Optional.ofNullable(columns).filter(cs -> cs.length != 0).isPresent()) {
return tableData;
}
//定义新的表数据并初始化其标题
TableData<T> nowTable = new TableData<>();
//按行遍历tableData的所有数据过滤掉与nowTable中指定行数据一致的行数据之后添加未被过滤的数据
Optional.ofNullable(tableData).filter(td -> !td.isEmpty()).ifPresent(td -> {
nowTable.addTitle(tableData.getColumnName());
td.rowStream().filter(list -> {
boolean isRepeat = true;
for (String column : columns) {
//获取指定列数据若新表中该列的数据包含了当前的数据则返回false
if (nowTable.getColumnList(column).contains(list.get(tableData.getFieldIndex(column)))) {
isRepeat = true;
continue;
} else {
isRepeat = false;
break;
}
}
//返回不重复的结果
return !isRepeat;
//由于返回的元素为封装类对象需要对元素脱壳处理处理方式为直接返回即可
}).map(list -> list.stream().map(e -> e.get()).collect(Collectors.toList())).forEach(nowTable::addRow);
});
return nowTable;
}
}

View File

@ -24,7 +24,7 @@ import java.util.stream.Stream;
* <b>编码时间</b>2020年12月17日上午8:24:47
* </p>
* <p>
* <b>修改时间</b>2020年12月17日上午8:24:47
* <b>修改时间</b>2021年2月19日下午6:39:48
* </p>
*
* @author 彭宇琦
@ -367,8 +367,8 @@ public class TableData<T> {
* @return 指定列的所有数据
*/
public ArrayList<Optional<T>> getColumnList(String columnName) {
columnName = Optional.ofNullable(columnName).filter(tableMap::containsKey)
.orElseThrow(() -> new IllegalDataException("不存在的元素列"));
Optional.ofNullable(columnName).filter(tableMap::containsKey)
.orElseThrow(() -> new IllegalDataException("不存在的元素列" + columnName));
ArrayList<Optional<T>> columnDataList = new ArrayList<>();
columnDataList.addAll(tableMap.get(columnName));
@ -393,7 +393,7 @@ public class TableData<T> {
public Optional<T> getFirstData() {
return getFirstColumn().get(0);
}
/**
* 用于获取指定列与指定列的数据并以传入的字段顺序将获取到的每列数据进行存储
* <p>
@ -553,7 +553,7 @@ public class TableData<T> {
public void columnForEach(BiConsumer<String, List<Optional<T>>> action) {
tableMap.forEach(action);
}
/**
* 刷新表中最长与最短列的元素个数用于清空或删除表时的计算
*/
@ -591,4 +591,9 @@ public class TableData<T> {
return index;
}
}
@Override
public String toString() {
return "[" + tableMap + "]";
}
}