Back
Close

Java 8 – Streams Cookbook

javabullets
19.8K views
Previous: Matching and Reducing

Java 8 – Java 8 - Streams Cookbook - groupby, join and grouping

The origins of this article were my original blog post Java 8 - Streams Cookbook. This article provided a single main method and a number of different Streams examples. This post re-writes the article interactively using tech.io.

Cookbook

The lists we are using is a list of Tour de France winners -

public static final List<Winner> tdfWinners = Arrays.asList(
new Winner(2006, "Spain", "Óscar Pereiro", "Caisse d'Epargne–Illes Balears", 3657, Duration.parse("PT89H40M27S"), 8),
new Winner(2007, "Spain", "Alberto Contador", "Discovery Channel", 3570, Duration.parse("PT91H00M26S"), 4),
new Winner(2008, "Spain", "Carlos Sastre", "Team CSC", 3559, Duration.parse("PT87H52M52S"), 5),
new Winner(2009, "Spain", "Alberto Contador", "Astana", 3459, Duration.parse("PT85H48M35S"), 7),
new Winner(2010, "Luxembourg", "Andy Schleck", "Team Saxo Bank", 3642, Duration.parse("PT91H59M27S"), 12),
new Winner(2011, "Australia", "Cadel Evans", "BMC Racing Team", 3430, Duration.parse("PT86H12M22S"), 2),
new Winner(2012, "Great Britain", "Bradley Wiggins", "Team Sky", 3496, Duration.parse("PT87H34M47S"), 14),
new Winner(2013, "Great Britain", "Chris Froome", "Team Sky", 3404, Duration.parse("PT83H56M20S"), 14),
new Winner(2014, "Italy", "Vincenzo Nibali", "Astana", 3661, Duration.parse("PT89H59M06S"), 19),
new Winner(2015, "Great Britain", "Chris Froome", "Team Sky", 3360, Duration.parse("PT84H46M14S"), 16),
new Winner(2016, "Great Britain", "Chris Froome", "Team Sky", 3529, Duration.parse("PT89H04M48S"), 14 )
);

groupingBy

The groupingBy method allows us to collect the results into a Map. In this case we are grouping liss of Tour de France winners by the winners name -

// groupingby - make a map whose keys are names
Map<String, List<Winner>> namesVsWinner = com.javabullets.Winner.tdfWinners
		                                     .stream()
											 .collect(groupingBy(Winner::getName));

We can also collect Tour de France winners to csv -

String allTDFWinnersTeamsCSV = com.javabullets.Winner.tdfWinners
		                                             .stream()
													 .map(Winner::getTeam)
													 .collect(joining(", "));
Groupby and Collect Example
package com.javabullets;
// { autofold
import java.time.Duration;
import java.util.*;
import static java.util.stream.Collectors.toList;
import static java.util.stream.Collectors.*;
public class WinnersGroupby {
// }
public void winnersGroupby() {
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

Grouping

Grouping allows us to collect results according to a criteria.

For instance if we want to group Tour de France winners by Nationality then we would write -

Map<String, List<Winner>> winnersByNationality = com.javabullets.Winner.tdfWinners
                                                    .stream()
													.collect(groupingBy(Winner::getNationality));

Or we can count the number of winners from each nationality -

Map<String, Long> winsByNationalityCounting = com.javabullets.Winner.tdfWinners
                                                 .stream()
												 .collect(groupingBy(Winner::getNationality, counting()));
Grouping
package com.javabullets;
// { autofold
import java.time.Duration;
import java.util.*;
import static java.util.stream.Collectors.toList;
import static java.util.stream.Collectors.*;
public class WinnersGrouping {
// }
public void winnersGrouping() {
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

If you have liked this post, check out my personal blog which contains similar tutorials at www.javabullets.com.

You can also provide me feedback at martin at javabullets.com

Create your playground on Tech.io
This playground was created on Tech.io, our hands-on, knowledge-sharing platform for developers.
Go to tech.io
codingame x discord
Join the CodinGame community on Discord to chat about puzzle contributions, challenges, streams, blog articles - all that good stuff!
JOIN US ON DISCORD
Online Participants