$show=/label

Java 8 Stream Group By Count Example

SHARE:

A simple walkthrough on how to use group by count with Java 8 streams. An example demonstrating how to use the Collectors groupingBy() and counting()

1. Introduction


We will learn how to get the count using the stream group by count technique in this lesson. This is a very helpful way to do aggregated operations with the Java 8 stream grouping API.

Collectors.groupingBy() and Collectors.counting() are used to accomplish the group by count operation.

Let's look at some examples of stream grouping by count.

Java 8 Stream Group By Count Example


2. Java 8 Stream Group By Count


We will start with simple data, which is a list containing duplicate items, and then go on to more complicated data for a better understanding.

Stream Grouping in Java 8 By Count Example:

In the following programme, we have stored a variety of brand names in a list, many of which are repeated. Using the java stream group by count approach, we will now determine how many times each brand is repeated.

We mostly used three functions in this code.

Collectors.groupingBy() - This function requires two arguments and we passed Function.identity() and Collectors.counting().
Function.identity() - Takes each item from the stream and invokes the counting() method. If it finds the same key, it adds one to the current value.
Collectors.counting() - count increments by one if the same key is repeated more than once.

package com.javaprogramto.java8.collectors.groupby.count;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;

/**
 * Stream Group by count examples
 * 
 * @author JavaProgramTo.com
 *
 */

public class GroupByCountExample {

	public static void main(String[] args) {

		List<String> brands = new ArrayList<>();

		brands.add("Apple");
		brands.add("Google");
		brands.add("Nokia");
		brands.add("HTC");
		brands.add("HTC");
		brands.add("Google");
		brands.add("Google");
		brands.add("Google");
		brands.add("Apple");
		brands.add("Apple");
		brands.add("Apple");

		Map<String, Long> countByBrand = brands.stream()
				.collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));
		
		System.out.println("Group by count : "+countByBrand);

	}
}
 

Output:
Group by count : {Google=4, Apple=4, HTC=2, Nokia=1}
 

Examine the result of the preceding programme, which displays the unique brand names with a count. This figure indicates the number of times the brand was mentioned in the input list.

You can use the same code to make your scenario functioning.


3. Java 8 Stream Group By Count With filter


Next, take the different types of smartphone models and filter the names to get the brand. Finally get only brand names and then apply the count logic.

Now, using the map() method, filter or transform the model name into brand. Next,  In map() method, we do split the string based on the empty string and take the first value from index 0 which holds the brand name.

We presume that the combination of brand name and model name is always present in the input list. The brand name will always come first, followed by the model name separated by a space.

Look at the output, and it will be the same as the output from the previous section program.
package com.javaprogramto.java8.collectors.groupby.count;

import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import java.util.stream.Collectors;

/**
 * Stream Group by count examples
 * 
 * @author JavaProgramTo.com
 *
 */

public class GroupByCountFilterExample {

	public static void main(String[] args) {

		List<String> modelNames = new ArrayList<>();

		// adding the model names to the list
		modelNames.add("Apple iphone 12");
		modelNames.add("Google Pixel 5");
		modelNames.add("Nokia 3.1 plus");
		modelNames.add("HTC Desire 21 Pro 5G");
		modelNames.add("HTC Wildfire E1");
		modelNames.add("Google Pixel");
		modelNames.add("Google nexus 6p");
		modelNames.add("Google nexus");
		modelNames.add("Apple iphone 5");
		modelNames.add("Apple iphone 3s");
		modelNames.add("Apple iphone 12 max");

		Map<String, Long> countByBrand = modelNames.stream()
				.map(model -> model.split(" ")[0])
				.collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));

		System.out.println("Group by brands count : " + countByBrand);

	}

}

 
Output:
Group by brands count : {Google=4, Apple=4, HTC=2, Nokia=1}
 
Let us now remove the brand "HTC" from our groupby outcomes. To filter, use the stream filter() method, which accepts the condition argument as a Predicate. This criteria is used to filter brand names. You can specify any criterion, such as if the brand name length < 5, then just those values will be passed to the group by function, as seen below.
Map<String, Long> countByBrand = modelNames.stream()
		.map(model -> model.split(" ")[0]).filter(brandName -> !brandName.equalsIgnoreCase("HTC") )
		.collect(Collectors.groupingBy(Function.identity(), Collectors.counting()));

System.out.println("Group by brands count : " + countByBrand);

// output: Group by brands count : {Google=4, Apple=4, Nokia=1}
 

4. Conclusion


In this post, you've seen how to stream group by count in java 8 with examples.


COMMENTS

BLOGGER

About Us

Author: Venkatesh - I love to learn and share the technical stuff.
Name

accumulo,1,ActiveMQ,2,Adsense,1,API,37,ArrayList,18,Arrays,24,Bean Creation,3,Bean Scopes,1,BiConsumer,1,Blogger Tips,1,Books,1,C Programming,1,Collection,8,Collections,37,Collector,1,Command Line,1,Comparator,1,Compile Errors,1,Configurations,7,Constants,1,Control Statements,8,Conversions,6,Core Java,149,Corona India,1,Create,2,CSS,1,Date,3,Date Time API,38,Dictionary,1,Difference,2,Download,1,Eclipse,3,Efficiently,1,Error,1,Errors,1,Exceptions,8,Fast,1,Files,17,Float,1,Font,1,Form,1,Freshers,1,Function,3,Functional Interface,2,Garbage Collector,1,Generics,4,Git,9,Grant,1,Grep,1,HashMap,2,HomeBrew,2,HTML,2,HttpClient,2,Immutable,1,Installation,1,Interview Questions,6,Iterate,2,Jackson API,3,Java,32,Java 10,1,Java 11,6,Java 12,5,Java 13,2,Java 14,2,Java 8,128,Java 8 Difference,2,Java 8 Stream Conversions,4,java 8 Stream Examples,12,Java 9,1,Java Conversions,14,Java Design Patterns,1,Java Files,1,Java Program,3,Java Programs,114,Java Spark,1,java.lang,4,java.util. function,1,JavaScript,1,jQuery,1,Kotlin,11,Kotlin Conversions,6,Kotlin Programs,10,Lambda,2,lang,29,Leap Year,1,live updates,1,LocalDate,1,Logging,1,Mac OS,3,Math,1,Matrix,6,Maven,1,Method References,1,Mockito,1,MongoDB,3,New Features,1,Operations,1,Optional,6,Oracle,5,Oracle 18C,1,Partition,1,Patterns,1,Programs,1,Property,1,Python,2,Quarkus,1,Read,1,Real Time,1,Recursion,2,Remove,2,Rest API,1,Schedules,1,Serialization,1,Servlet,2,Sort,1,Sorting Techniques,8,Spring,2,Spring Boot,23,Spring Email,1,Spring MVC,1,Streams,31,String,61,String Programs,28,String Revese,1,StringBuilder,1,Swing,1,System,1,Tags,1,Threads,11,Tomcat,1,Tomcat 8,1,Troubleshoot,26,Unix,3,Updates,3,util,5,While Loop,1,
ltr
item
JavaProgramTo.com: Java 8 Stream Group By Count Example
Java 8 Stream Group By Count Example
A simple walkthrough on how to use group by count with Java 8 streams. An example demonstrating how to use the Collectors groupingBy() and counting()
https://blogger.googleusercontent.com/img/a/AVvXsEjz5mo2WWK3pVYAzMtkoL3zh50Wfis4N0GxaL07Jte3Na1vRyPX_XApzWrQMzrMLhKnD4nlo2JpD-LbnIKHjGAK-HIUv6ZffSfJA3QU47fKNW7y6mMIjMDczmhetgHMbj82v8kUyf7dTsUdZHU7j_M4AWZVLj5KpuAWf5DLx_NP993sLTuptC7t0xse=w400-h225
https://blogger.googleusercontent.com/img/a/AVvXsEjz5mo2WWK3pVYAzMtkoL3zh50Wfis4N0GxaL07Jte3Na1vRyPX_XApzWrQMzrMLhKnD4nlo2JpD-LbnIKHjGAK-HIUv6ZffSfJA3QU47fKNW7y6mMIjMDczmhetgHMbj82v8kUyf7dTsUdZHU7j_M4AWZVLj5KpuAWf5DLx_NP993sLTuptC7t0xse=s72-w400-c-h225
JavaProgramTo.com
https://www.javaprogramto.com/2021/06/java-8-stream-group-by-count.html
https://www.javaprogramto.com/
https://www.javaprogramto.com/
https://www.javaprogramto.com/2021/06/java-8-stream-group-by-count.html
true
3124782013468838591
UTF-8
Loaded All Posts Not found any posts VIEW ALL Readmore Reply Cancel reply Delete By Home PAGES POSTS View All RECOMMENDED FOR YOU LABEL ARCHIVE SEARCH ALL POSTS Not found any post match with your request Back Home Sunday Monday Tuesday Wednesday Thursday Friday Saturday Sun Mon Tue Wed Thu Fri Sat January February March April May June July August September October November December Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec just now 1 minute ago $$1$$ minutes ago 1 hour ago $$1$$ hours ago Yesterday $$1$$ days ago $$1$$ weeks ago more than 5 weeks ago Followers Follow THIS PREMIUM CONTENT IS LOCKED STEP 1: Share to a social network STEP 2: Click the link on your social network Copy All Code Select All Code All codes were copied to your clipboard Can not copy the codes / texts, please press [CTRL]+[C] (or CMD+C with Mac) to copy Table of Content