Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> [PHP] ksort i array_count_values problemy z sortowaniem
bobo1
post
Post #1





Grupa: Zarejestrowani
Postów: 31
Pomógł: 1
Dołączył: 7.03.2008

Ostrzeżenie: (0%)
-----


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ę
Go to the top of the page
+Quote Post
skowron-line
post
Post #2





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


Pokaż więcej kodu.
Go to the top of the page
+Quote Post
bobo1
post
Post #3





Grupa: Zarejestrowani
Postów: 31
Pomógł: 1
Dołączył: 7.03.2008

Ostrzeżenie: (0%)
-----


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 />';
Go to the top of the page
+Quote Post
peter13135
post
Post #4





Grupa: Zarejestrowani
Postów: 1 447
Pomógł: 191
Dołączył: 26.03.2008

Ostrzeżenie: (0%)
-----


a czy to przypadkiem nie zwraca jednego wiersza ?
Go to the top of the page
+Quote Post
bobo1
post
Post #5





Grupa: Zarejestrowani
Postów: 31
Pomógł: 1
Dołączył: 7.03.2008

Ostrzeżenie: (0%)
-----


Tak zwraca. Tylko pytanie dlaczego?

Właściwie nie jeden wiersz a wartość: 1

Ten post edytował bobo1 21.08.2011, 19:13:52
Go to the top of the page
+Quote Post
skowron-line
post
Post #6





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


  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.
Go to the top of the page
+Quote Post
bobo1
post
Post #7





Grupa: Zarejestrowani
Postów: 31
Pomógł: 1
Dołączył: 7.03.2008

Ostrzeżenie: (0%)
-----


OK rozumiem, że 1 to true. Czyli tablica została posortowana. Tylko jak mogę wyświetlić tą posortowaną tablicę?
Go to the top of the page
+Quote Post
skowron-line
post
Post #8





Grupa: Zarejestrowani
Postów: 4 340
Pomógł: 542
Dołączył: 15.01.2006
Skąd: Olsztyn/Warszawa

Ostrzeżenie: (0%)
-----


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. ?>
Go to the top of the page
+Quote Post
bobo1
post
Post #9





Grupa: Zarejestrowani
Postów: 31
Pomógł: 1
Dołączył: 7.03.2008

Ostrzeżenie: (0%)
-----


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 (IMG:style_emoticons/default/smile.gif) . Wielkie dzięki za pomoc!!!
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 25.08.2025 - 01:35