java8 streamList转换使用详解
一、java8stream操作
List
第一种,实用于数据查询返回的是List
方法一、
Map;resultMap=lists .stream() .flatMap(map->map.entrySet().stream()) .collect(Collectors.toMap(e->e.getKey(),e->e.getValue(),(a,b)->a)));
方法二、
Mapmap=maps.stream() .map(Map::entrySet) .flatMap(Set::stream) .collect(Collectors.toMap(Map.Entry::getKey,Map.Entry::getValue,(a,b)->a)));
注意!这种转换方法后面的(a,b)->a这个是必须的,因为list转map可能会出现key值重复的情况,如果不指定去重规则,转换的时候是会报错的
第二种,实用于数据查询返回的是Listmaps
Map;resultMap=lists .stream() .collect(Collectors.toMap(Entry::getProtity,Entry::getProtity,(a,b)->a)));
这种实体类list就比较容易,在这个过程中还可以进行条件过滤,filter或者排序reversed,用到时加进去就可以,这里就不赘述了
补充知识:java8统计字符串字母个数的几种方法(有你没见到过的)
1.统计字符串字母个数(并且保持字母顺序)
比如:aabbbbbbbba喔喔bcabcdabcdeaaa
目前我做知道的有5种方式,如果你还有更好的,欢迎赐教
要求:统计字符串的字符个数,最好按顺序输出每个字符的个数
//方式1
publicstaticvoidletterCount1(Strings){
s=s.replaceAll("+","");
//1,转换成字符数组
charc[]=s.toCharArray();
Maptree=newTreeMap();
for(inti=0;iresult=Arrays.stream(s.split(""))
.sorted()
//.collect(Collectors.groupingBy(Function.identity(),Collectors.counting()));
.collect(Collectors.groupingBy(Function.identity(),TreeMap::new,Collectors.counting()));
System.out.println(result);
}
//或者
publicstaticvoidletterCount2_1(Strings)throwsException{
s=s.replaceAll("+","");
Streamwords=Arrays.stream(s.split(""));
MapwordsCount=words.collect(Collectors.toMap(k->k,v->1,
(i,j)->i+j));
System.out.println(wordsCount);
}
//方式3使用Collections.frequency
//其实就是字符串变成集合存每个字串,把每个字串循环跟集合比较
publicstaticvoidletterCount3(Strings){
s=s.replaceAll("+","");
Listlist=Arrays.asList(s.split(""));
Mapmap=newTreeMap();
for(Stringstr:list){
map.put(str,Collections.frequency(list,str));
}
System.out.println(map);
}
//方式4
publicstaticvoidletterCount4(Strings){
s=s.replaceAll("+","");
String[]strs=s.split("");
Mapmap=newTreeMap();
for(Stringstr:strs){
map.put(str,stringCount(s,str));
}
System.out.println(map);
}
//方式5
publicstaticvoidletterCount5(Strings){
s=s.replaceAll("+","");
String[]strs=s.split("");
Mapmap=newTreeMap();
for(Stringstr:strs){
map.put(str,stringCount2(s,str));
}
System.out.println(map);
}
//巧用split
publicstaticintstringCount(Stringmaxstr,Stringsubstr){
//注意
//1.比如qqqq,没有找到,则直接返回这个字符串
//2.比如qqqjava,末尾没有其他字符,这时也不会分割,所以可以添加一个空格
//3.java11开头没有字符,没有关系,自动空填充
//4.对于特殊字符,要注意使用转义符
intcount=(maxstr+"").split(substr).length-1;
//System.out.println("\""+minstr+"\""+"字符串出现次数:"+count);
returncount;
}
//如果要不区分大小写,则compile(minstr,CASE_INSENSITIVE)
publicstaticintstringCount2(Stringmaxstr,Stringsubstr){
intcount=0;
Matcherm=Pattern.compile(substr).matcher(maxstr);
while(m.find()){
count++;
}
returncount;
}
2.统计字符串的单词个数
这个其实跟上面一样的,下面只写一个简洁的方法
publicstaticvoidwordStringCount(Strings){
//这里开始是字符串,分割后变成字符串流
Mapresult=Arrays.stream(s.split("\\s+"))
.map(word->word.replaceAll("[^a-zA-Z]",""))
.collect(Collectors.groupingBy(Function.identity(),Collectors.counting()));
System.out.println(result);
}
3.统计文本单词个数
//统计一个文本中单词的个数
publicstaticvoidwordFileCount(Stringpath)throwsIOException{
//这里一开始字符串流
//先分割
//在变成字符流
//在筛选
Mapresult=Files.lines(Paths.get(path),Charset.defaultCharset())
.parallel()
//字符串流--分割--字符串流
.flatMap(str->Arrays.stream(str.split("+")))
.map(word->word.replaceAll("[^a-zA-Z]",""))
//去掉空
.filter(word->word.length()>0)
.collect(Collectors.groupingBy(Function.identity(),Collectors.counting()));
System.out.println(result);
}
//优化:更精确的是根据非单词来分组
publicstaticvoidwordFileCount0(Stringpath)throwsIOException{
Mapresult=Files.lines(Paths.get(path),Charset.defaultCharset())
.parallel()
//字符串流--分割--字符串流
.flatMap(str->Arrays.stream(str.split("[^a-zA-Z]+")))
//去掉\n
.filter(word->word.length()>0)
.collect(Collectors.groupingBy(Function.identity(),Collectors.counting()));
System.out.println(result);
}
以上这篇java8streamList转换使用详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。