I have a foreach loop which echo
's each of the property types in my search results. The code is as follows:
<?php
foreach($search_results as $filter_result) {
echo $filter_result['property_type'];
}
?>
The above code returns:
house house house house flat flat flat
I would like to do something similar to the MySQL 'distinct', but I am not sure how to do it on a foreach statement.
I want the above code to return:
- house
- flat
Not repeat every item each time. How can I do this?
I'd use two loops here. One to build an array of distinct
property_type
fields (you can use code in the loop to check the item doesn't already exist).Then, use a second loop to step through the array and
echo
the list of items.I was thinking there was some parameter to the in_array() function to get the count of the items found.
But is doesn't exist.
So try with array_unique().
The better way is to duplicate the array before the
foreach
loop and apply this function.http://php.net/manual/en/function.array-unique.php
Example:
You will need to alter it slightly to check using the
property_type
part of your array.You would have to keep track of already echoed values or build a new unique array of the values of all the $filter_result['property_type']. But that would then require you to iterate over that array once more to actually print. So keeping track would be better.
Try with: