Paddy Hallihan
Paddy Hallihan

Reputation: 1686

PHP - finding unique values within an array

I am creating an ecommerce site and am trying to get a list of top selling products.

The following example shows an array of product ids from sales, and is outputting the top selling products in the form of 'product id' x 'number of sales'

<?php
$product_ids = [58,58,68,39,4,118,14,54,39,118,58];
$top_selling_products = "";

$product_sales = array_count_values($product_ids);
arsort($product_sales);
$i = 0;
foreach($product_sales as $sales){
    $i++;
    $product_id = array_search($sales,$product_sales);
    $top_selling_products .= $product_id.' x '.$sales.'<br />';
    if($i == 5){break;}
}

echo $top_selling_products;
?>

However, it's not exactly doing what I want, at present this is outputting the following:

58 x 3
118 x 2
118 x 2
54 x 1
54 x 1

Where it should be:

58 x 3
118 x 2
39 x 2
54 x 1
14 x 1

It is getting the last item in the array with the same index so when there are two or more products with the same amount of sales it is not picking them up.

What would be the best way to get all unique ids?

Upvotes: 0

Views: 61

Answers (4)

Niklesh Raut
Niklesh Raut

Reputation: 34914

You can achieve your goal by using array_count_values + Simple foreach + Sort array by Keeping key with arsort

$product_ids = [58,58,68,39,4,118,14,54,39,118,58];
$arr = array_slice(array_count_values($product_ids), 0, 5, true);
arsort($arr);
$str = "";
foreach($arr as $k=>$v)
  $str .= "$k X $v \n";
echo $str;

Live Demo

Output is as :

58 X 3 
118 X 2 
39 X 2 
68 X 1 
4 X 1 

Upvotes: 0

Progrock
Progrock

Reputation: 7485

<?php

$product_ids      = [58,58,68,39,4,118,14,54,39,118,58];
$product_sales    = array_count_values($product_ids);
arsort($product_sales);
$top_five_sellers = array_slice($product_sales, 0, 5, true);
foreach($top_five_sellers as $id => $count)
    echo $id.' x '.$count."\n";

Output:

58 x 3
39 x 2
118 x 2
68 x 1
4 x 1

Upvotes: 1

Mitya
Mitya

Reputation: 34556

Your code can be simplified to use something like array_map():

arsort($product_sales);
$output = array_map(function($sales, $pid) {
    return $pid.' x '.$sales;
}, $product_sales, array_keys($product_sales));
echo implode('<br />', $output);

Upvotes: 1

u_mulder
u_mulder

Reputation: 54831

You already have what you need in $product_sales:

foreach($product_sales as $id => $count){
    $i++;
    $top_selling_products .= $id.' x '.$count.'<br />';
    if($i == 5){break;}
}

Upvotes: 2

Related Questions