count number of occurances of a particular object from the array list using java8

Karthikeyan :

Let Say, am having an array list :

catalog id--->901
Catalog name --->series277
catalog id--->901
Catalog name --->series277
catalog id--->545
Catalog name --->series285
catalog id--->545
Catalog name --->series285
catalog id--->545
Catalog name --->series285
catalog id--->546
Catalog name --->series685
catalog id--->546
Catalog name --->series685
catalog id--->40962
Catalog name --->series19348
catalog id--->40962
Catalog name --->series19348
catalog id--->40962
Catalog name --->series19348
catalog id--->40962

From this list, i want to find the number of occurances like below.

catalog id--->901    -- 2
catalog id--->545    -- 3
catalog id--->546    -- 2
catalog id--->40962  -- 4

My goal is, based on the number of occurances of id i want to create a loop to iterate further.

Please find my java code for the Arraylist creation

List<Catalog> catalogList2 = new ArrayList<Catalog>();
for (SearchHit hit1 : searchHits2)
{
  sourceAsMap2 = hit1.getSourceAsMap();
  catalog2 = new Catalog();
  catalog2.setId(String.valueOf(sourceAsMap2.get("catalog_id")));
  catalog2.setCatalog_name(String.valueOf(sourceAsMap2.get("catalog_name")));
  catalogList2.add(catalog2);
}

UPDATE

Trying to implement the below case :

for(int i=0;i<catalogList2.size();i++) {

        // want to find the number of occurances for catalog.getId()
        //Then i want to create a loop based on the number of occurances of catalog id
        for(int i=0;i<catalog_id_occurances.size;i++)
        {
            //Have to do something.
        }

    }
Aman Chhabra :

You can do it with Streams:

catalogs.stream().collect(
                Collectors.groupingBy(Catalog::getId, Collectors.counting()));

Output:

jshell> catalogList.stream().collect(
   ...>                 Collectors.groupingBy(Catalog::getId, Collectors.counting()));
$43 ==> {901=2, 545=3, 546=2, 40962=4}

--EDIT--

In case you want to manipulate the output further or want to print in some customer format you can use below:

catalogList.stream().collect(Collectors.groupingBy(Catalog::getId, Collectors.counting())).entrySet().stream().map(p->"catalog id--->"+p.getKey()+"    -- "+p.getValue()).forEach(System.out::println);

Output:

catalog id--->901    -- 2
catalog id--->545    -- 3
catalog id--->546    -- 2
catalog id--->40962  -- 4

Guess you like

Origin http://43.154.161.224:23101/article/api/json?id=113848&siteId=1