Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: [PHP][rozwiązany]Usunięcie dziur z tablicy
Forum PHP.pl > Forum > Przedszkole
Marr
Witam, pisałem w innym temacie o mnożeniu elementów tablic jednak jak sie okazuje mój problem sprowadza się do usuwania dziur z tablicy. Postanowiłem się więc za to zabrać i tak:

  1. <?php
  2. $mnoznikorg = $rekord['mnoznik'];
  3.    $mnoznikorg = explode(';',$mnoznikorg);
  4.    $in = 0;
  5.    foreach ($mnoznikorg as $tabelka){
  6.        if ($tabelka != '')
  7.            {
  8.            $tabelka = $tablica[&#092;"$in\"];
  9.            $in++ ;
  10. }            }
  11.    $tablica = implode(';',$tablica);
  12. ?>

Pobieram tablice z bazy która jest w formie stringa z separatorem ; więc exploduję go i przeglądam otrzymaną tablice a podczas tego sprawdzam czy dany element nie jest równy '' (dwa apostrofy, nie cudzysłow) -> jeżeli nie to chce zapisać element do tablicy. Po wyjściu z pętli chciałem skleić otrzymaną tablice w string tak żeby zobaczyć czy mi się udało i dostaje takie cos:

Warning: implode() [function.implode]: Invalid arguments passed in C:\Program Files\WebServ\httpd\system\modules\faktura2.php on line 390

a wg mnie argumenty w tej funkcji są całkiem niekiepskie smile.gif Możecie mi powiedzieć co robię źle? Jestem prawie pewien, że robię jakąś elementarną głupotę jednak nie potrafię sobie z nią poradzić.
nospor
operujesz na $tablica ktora nigdzie nie jest definiowana
Marr
kurcze, wykaże się tu głupotą ale jak mawia mój profesor głupi jest nie ten co pyta o głupote tylko ten, który kiwa, że rozumie a nie rozumie smile.gif Tak więc -> jak mam zadeklarować tą tablicę by to działało? snitch.gif
nospor
a skad mamy wiedziesz co ty chcesz w tej $tablica miec? Uzywasz jej tak jakby tam cos bylo, wiec chyba powinienes sam wiedziec co tam masz
Marr
nie nie, właśnie chcę zapisać elementy do nowej tablicy, począwszy od indeksu 0 a później go inkrementuje
nospor
kurcze, ale masz taki kod:
$tabelka = $tablica[$in];

Ewidentnie w tym kodzie cos pobierasz z $tablica. Ja nie mowie o $tabelka tylko mowie o $tablica. Wiec skoro cos stamtad pobierasz to musisz cos miec winksmiley.jpg
Marr
to ja tu w takim razie czegoś nie rozumiem, całość wygląda tak:
  1. <?php
  2. $zapytanie = mysql_query ("SELECT * FROM zamowienia WHERE id=$getid");
  3.    while ($rekord = mysql_fetch_assoc ($zapytanie)) {
  4.        $id = $rekord['id'];
  5.        $uslugi = $rekord['usluga'];
  6.        $data_zlozenia = $rekord['data_zlozenia'];
  7.        $data_realizacji = $rekord['data_realizacji'];
  8.        $status = $rekord['status'];
  9.        $faktura = $rekord['faktura'];
  10.  
  11.        $usluga = explode(';', $uslugi);
  12.        
  13.    $mnoznikorg = $rekord['mnoznik'];
  14.    $mnoznikorg = explode(';',$mnoznikorg);
  15.    $in = 0;
  16.    foreach ($mnoznikorg as $tabelka){
  17.        if ($tabelka != '')
  18.            {
  19.            $tabelka = $tablica["$in"];
  20.            $in++ ;
  21. }            }
  22.    $tablica = implode(';',$tablica);
  23. ?>

więc wygląda na to ze $tabelka to poszczególny element tablicy $mnoznikorg w foreach czy nie?
nospor
kurcze, chlopie, no to nie:
$tabelka = $tablica["$in"];
a:
$tablica["$in"] = $tabelka;

patrz w ktora strone przypisujesz

cały czas ci mowie ze cos pobierasz z $tablica to ty nie jazysz ze ty chesz zapisac do $tablica a nie pobrac. Wlacz myslenie, wypij kawe, obudź sie winksmiley.jpg
Marr
<poszedl_po_kawe> dzięki, mówiłem, że jakaś głupota ;] tak czy inaczej fenksy rolleyes.gif
tomm
zamiast 

$tabelka = $tablica["$in"];

powinieneś mieć

$tablica[$in] = $tabelka

czyli dla każdej nie pustej $tabelka dodajesz ją na koniec tablicy $tablica i poxniej ją implodujesz
Marr
Tomm niestety, ale Nospor napisał dokładnie to samo, a więc tym samym zgarnął podziękówke smile.gif Dzięki za chęć pomocy tak czy inaczej.
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.