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;i result=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("+",""); Stream words=Arrays.stream(s.split("")); Map wordsCount=words.collect(Collectors.toMap(k->k,v->1, (i,j)->i+j)); System.out.println(wordsCount); } //方式3使用Collections.frequency //其实就是字符串变成集合存每个字串,把每个字串循环跟集合比较 publicstaticvoidletterCount3(Strings){ s=s.replaceAll("+",""); List list=Arrays.asList(s.split("")); Map map=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(""); Map map=newTreeMap (); for(Stringstr:strs){ map.put(str,stringCount(s,str)); } System.out.println(map); } //方式5 publicstaticvoidletterCount5(Strings){ s=s.replaceAll("+",""); String[]strs=s.split(""); Map map=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{ Map result=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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。