Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!

Ogłoszenie

Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.

#1  2012-09-26 13:52:20

  Paad - Użytkownik

Paad
Użytkownik
Skąd: Częstochowa
Zarejestrowany: 2009-02-22

[php] problem ze zwrotem tablicy

Witam

Próbuję sobie napisać skrypt, który będzie mi przeliczał Bajty na MegaBajty i wyżej.
funkcje converter_divisor działa dobrze

Kod:

var_dump($helper);

osiąga takie wartości jakie powinien, ale po zwróceniu tej zmiennej

Kod:

$worth=converter_divisor($value, 0);

nie jest ona przypisywana do zmiennej $worth.

Poniżej cały skrypt, jeżeli mógłby ktoś zerknąć i podpowiedzieć mi, co robię nie tak to byłbym wdzięczny.

Kod:

<?php
echo "start";
echo converter(1234567890)."<br/>";
echo "stop";

function converter($value){
    $unit=array('B','KB','MB','GB','TB');
    $worth=converter_divisor($value, 0);
    var_dump($worth);
    }

function converter_divisor($value, $sentinel){
    while(($value/1024)>1)
        {
        converter_divisor(($value/1024),($sentinel+1));
        $helper=array($value,$sentinel);
        return $helper;
        }
    echo $value." ".$sentinel."<br/>";
    $helper=array($value,$sentinel);
    var_dump($helper);
    return $helper;
}
?>

[url=http://www.luckysaloon.pl/]pub Częstochowa[/url] | [url=http://nova-it.eu]strony www[/url]

Offline

 

#2  2012-09-26 14:56:21

  jezoo - Dzięcioł

jezoo
Dzięcioł
Skąd: Z lasu
Zarejestrowany: 2005-09-02

Re: [php] problem ze zwrotem tablicy

Taki wynik Ciebie interesuje?

Kod:

start
1.1497809458524 3
array(2) {
  [0]=>
  float(1.1497809458524)
  [1]=>
  int(3)
}
WORTH = 
array(2) {
  [0]=>
  int(1234567890)
  [1]=>
  int(0)
}
stop

[img]http://intershock.pl/images/icons/freebsd.jpg[/img] [img]http://www.the-eleven.com/site_media/static/img/postgresql_powered.png[/img] [img]http://www.wwgmc.com/images/badge_php.gif[/img]
LRU #480459

Offline

 

#3  2012-09-26 21:19:37

  Paad - Użytkownik

Paad
Użytkownik
Skąd: Częstochowa
Zarejestrowany: 2009-02-22

Re: [php] problem ze zwrotem tablicy

Tą wartość próbuję zwrócić:

1.1497809458524 3[/quote]
niestety, jak zauważyłeś do worth przypisuje mi całkiem, co innego i nie rozumiem dlaczego.

W kolejnym kroku będę próbował zaokrąglić tą liczbę do 2 miejsc po przecinku.

var_dumpy - są po to, żebym widział, co się dzieje.
docelowo ich nie będzie.
będę zwracał wynik w postaci

Kod:

return $worth[0].$unit[$worth[1]];

Ostatnio edytowany przez Paad (2012-09-26 21:22:08)


[url=http://www.luckysaloon.pl/]pub Częstochowa[/url] | [url=http://nova-it.eu]strony www[/url]

Offline

 

#4  2012-09-27 08:57:50

  czadman - Bicycle repairman

czadman
Bicycle repairman
Skąd: Wrocław
Zarejestrowany: 2005-07-08

Re: [php] problem ze zwrotem tablicy

To błąd logiczny. Należy zmienić funkcję, aby była pewność, że zwraca wartość we właściwym miejscu.
http://ideone.com/lGzUF

ps. dziwna języka ta php ;)

ps2. Jeśli nie chcesz mieć takich problemów to zainstaluj sobie jakieś środowisko do deweloperki w php z debuggerem. wszelakie var_dumpy są dobre, ale do "kilkulinijkowców".

Ostatnio edytowany przez czadman (2012-09-27 09:04:46)


[url=http://www.debian.org/][img]http://www.debian.org/logos/openlogo-nd-50.png[/img][/url]

Offline

 

#5  2012-09-27 11:51:00

  TheAnt - Użytkownik

TheAnt
Użytkownik
Skąd: Silesia Moloch
Zarejestrowany: 2012-01-24
Serwis

Re: [php] problem ze zwrotem tablicy

Hmmmm.... funkcja [u]converter[/u] wywołuje funkcję [u]converter_divisor[/u].
W funkcji [u]converter_divisor[/u] jest użyte [b]return[/b].
Ale w funkcji [u]converter[/u] już nie, masz tylko proste przypisanie do zmiennej worth i powrót.
Spróbuj dać tak:

Kod:

function converter($value){
    $unit=array('B','KB','MB','GB','TB');
    $worth=converter_divisor($value, 0);
    var_dump($worth);
    return $worth;
}

bo rozumiem, że w $worth jest to co ma być zwrócone?
A tak to chyba zmienna $worth jest lokalnie modyfikowana ale na poziomie głównym jest niewidoczna/niezmieniona.

Przepraszam, jeśli bredzę...
TheAnt


If I go insane please don't put your wires in my brain...

Offline

 

#6  2012-09-27 12:07:25

  Paad - Użytkownik

Paad
Użytkownik
Skąd: Częstochowa
Zarejestrowany: 2009-02-22

Re: [php] problem ze zwrotem tablicy

[quote=TheAnt]Hmmmm.... funkcja [u]converter[/u] wywołuje funkcję [u]converter_divisor[/u].
W funkcji [u]converter_divisor[/u] jest użyte [b]return[/b].
Ale w funkcji [u]converter[/u] już nie, masz tylko proste przypisanie do zmiennej worth i powrót.
[...][/quote]
Nie zwracam [u]$worth[/u] w funkcji [u]converter[/u], bo funkcja [u]converter_divisor[/u] przypisuje mi do  [u]$worth[/u], błędny wynik (widzę to już po var_dump).

a jak już będę zwracał to tak jak pisałem wyżej

return $worth[0].$unit[$worth[1]];[/quote]
Dzięki [b]czadman[/b] zaraz pomyślę - uparłem się, żeby zrobić to rekurencyjnie i chyba niepotrzebnie ;) ale próbuję dalej.


[url=http://www.luckysaloon.pl/]pub Częstochowa[/url] | [url=http://nova-it.eu]strony www[/url]

Offline

 

Stopka forum

Powered by PunBB
© Copyright 2002–2005 Rickard Andersson
To nie jest tylko forum, to nasza mała ojczyzna ;-)

[ Generated in 0.015 seconds, 11 queries executed ]

Informacje debugowania

Time (s) Query
0.00011 SET CHARSET latin2
0.00008 SET NAMES latin2
0.00104 SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='3.138.175.166' WHERE u.id=1
0.00350 REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '3.138.175.166', 1732758612)
0.00032 SELECT * FROM punbb_online WHERE logged<1732758312
0.00060 SELECT topic_id FROM punbb_posts WHERE id=211910
0.00022 SELECT id FROM punbb_posts WHERE topic_id=22052 ORDER BY posted
0.00069 SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=22052 AND t.moved_to IS NULL
0.00056 SELECT search_for, replace_with FROM punbb_censoring
0.00365 SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=22052 ORDER BY p.id LIMIT 0,25
0.00111 UPDATE punbb_topics SET num_views=num_views+1 WHERE id=22052
Total query time: 0.01188 s