> -----Original Message----- > From: David Nicholson [mailto:[EMAIL PROTECTED] > Sent: 09 July 2003 15:08 > > This is a reply to an e-mail that you wrote on Wed, 9 Jul > 2003 at 14:55, > lines prefixed by '>' were originally written by you. > > Having STFM I am wondering if anyone knows of a quick antithesis to > > array_unique? We have an array in which we need to return all > > duplicate > > values instead of the non-duplicates.=20 > > How about: > > $array1 = array("dupe","dupe","another item"); > $valuecount = array(); > foreach($array1 as $value){ > if(isset($valuecount[$value])){ > $valuecount[$value]++; > } else { > $valuecount[$value] = 1; > } > } > $dupes = array(); > foreach($valuecount as $value=>$count){ > if($count>1){ > array_push($dupes,$value); > } > } > // $dupes now contains all duplicate values. > > There may be a quicker way of doing it though...
Well, for a kick-off, how about making use of array_count_values() (http://www.php.net/array_count_values)? $array1 = array("dupe","dupe","another item"); $dupes = array(); foreach(array_count_values($array1) as $value=>$count){ if($count>1){ $dupes[] = $value; } } I think judicious applications of array_unique() and array_diff() could also do the job, although I don't know how this compares for efficiency: $dupes = array_unique(array_diff($array1, array_unique($array1))); Cheers! Mike --------------------------------------------------------------------- Mike Ford, Electronic Information Services Adviser, Learning Support Services, Learning & Information Services, JG125, James Graham Building, Leeds Metropolitan University, Beckett Park, LEEDS, LS6 3QS, United Kingdom Email: [EMAIL PROTECTED] Tel: +44 113 283 2600 extn 4730 Fax: +44 113 283 3211 -- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php