Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP] ksort i array_count_values problemy z sortowaniem
Forum PHP.pl > Forum > Przedszkole
bobo1
Witam,

Mam problem z posortowaniem tablicy.

1. Z bazy danych wyciągam dane - otrzymuje tablice, którą przetwarzam przy pomocy array_count_values
2. Otrzymuję tablice:
Array
(
[1] => 6
[3] => 1
[2] => 2
)

3. Następnie chcę posortować według klucza tablicę przy pomocy ksort. (Generalnie każdy sposób sortowania nie zwraca tablicy.)
4. Wyświetlamy dane korzystając z foreach.

Otrzymuje błąd:
Warning: Invalid argument supplied for foreach() in

Generalnie problem polega na tym, że po zastosowaniu funkcji ksort nie mam już tablicy. Korzystając z
  1. echo '<pre>';
  2. print_r($tablica);
  3. echo '</pre>';


Otrzymuję: 1

Pytanie:
- Co robię źle
- Jak posortować taką tablicę
skowron-line
Pokaż więcej kodu.
bobo1
Upraszczając:

  1. $sql = "SELECT id, COUNT(*) AS `count` FROM table";
  2. $result = mysql_query($sql) or die('Nie można wykonać zapytania! <br /> Błąd:'.mysql_error().'<br />Zapytanie: '.$sql.'');
  3.  
  4. $idArray = array();
  5.  
  6. while ($row = mysql_fetch_array($result))
  7. {
  8. $idArray[] = $row['count'];
  9. }
  10.  
  11. $idArray= array_count_values($idArray);
  12.  
  13. $idArray = ksort($idArray);
  14.  
  15. foreach($idArray as $key => $value)
  16. echo ' '.$key.' - '.$value.' <br />';
peter13135
a czy to przypadkiem nie zwraca jednego wiersza ?
bobo1
Tak zwraca. Tylko pytanie dlaczego?

Właściwie nie jeden wiersz a wartość: 1
skowron-line
  1. <?php
  2. echo '<pre>';
  3.  
  4. $a = array(3 => 1, 2=> 3, 1=> 2);
  5.  
  6. print_r($a);
  7.  
  8. $b = ksort($a);
  9.  
  10.  
  11. print_r($b);
  12. print_r($a);

a tu wyjaśnienie z manuala
Cytat
Zwraca TRUE w przypadku powodzenia, FALSE w przypadku błędu.
czyli w twoim przypadku 1 to TRUE.
http://pl2.php.net/manual/pl/function.ksort.php czytanie kluczem do zrozumienia.
bobo1
OK rozumiem, że 1 to true. Czyli tablica została posortowana. Tylko jak mogę wyświetlić tą posortowaną tablicę?
skowron-line
Cytat(bobo1 @ 21.08.2011, 19:44:16 ) *
Tylko jak mogę wyświetlić tą posortowaną tablicę?

  1. <?php
  2. $a = array(3 => 1, 2=> 3, 1=> 2);
  3. ksort($a);
  4. foreach($a as $key => $value)
  5. {
  6. echo $key .'=> '. $value .'<br />';
  7. }
  8. ?>
bobo1
Wyjaśnienie dla tych, którzy będą mieli podobny problem i nie zauważą tego w kodzie.

Aby wyświetlić zawartość posortowanie tablicy

$b = ksort($a)

należy donieść się do $a. Odwołując się do $b otrzymamy 1 smile.gif. Wielkie dzięki za pomoc!!!
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.