Почему он показывает только 2 из 3 массивов? - PullRequest
0 голосов
/ 26 июля 2011

Я не уверен, почему это происходит. Вот мой XML:

<ResultSet>
<chats>
    <chat>
        <messages>
            <sms>
                <from>Bisma Iqbal</from>
                <msg>Hi</msg>
                <sent>1311612055</sent>
            </sms>
            <sms>
                <from>Bisma Iqbal</from>
                <msg>Hi</msg>
                <sent>1311612068</sent>
            </sms>
            <sms>
                <from>Bisma Iqbal</from>
                <msg>Hi</msg>
                <sent>1311612074</sent>
            </sms>
            <sms>
                <from>Bisma Iqbal</from>
                <msg>Hi</msg>
                <sent>1311612186</sent>
            </sms>
        </messages>
        <contact>Bisma Iqbal</contact>
    </chat>
    <chat>
        <messages>
            <sms>
                <from>Javaid Iqbal</from>
                <msg>this is the first message</msg>
                <sent>1311612055</sent>
            </sms>
            <sms>
                <from>Javaid Iqbal</from>
                <msg>this is the second message</msg>
                <sent>1311612055</sent>
            </sms>
        </messages>
        <contact>Javaid Iqbal</contact>
    </chat>
    <chat>
        <messages>
            <sms>
                <from>Ankur Shahi</from>
                <msg>Wanna play dawg at 7:15</msg>
                <sent>1311632708</sent>
            </sms>
            <sms>
                <from>Ankur Shahi</from>
                <msg>Wanna play dawg at 7:15</msg>
                <sent>1311632708</sent>
            </sms>
            <sms>
                <from>Ankur Shahi</from>
                <msg>Wanna play dawg at 7:15</msg>
                <sent>1311632708</sent>
            </sms>
        </messages>
        <contact>Ankur Shahi</contact>
    </chat>
</chats>
</ResultSet>

Вот мой код:

require_once('global.php');
$statement = $db->prepare("SELECT * FROM user WHERE id=1");
$statement->execute();
$result = $statement->fetchObject();
$string = $result->chats;
$chats = GBA($string, "<chat>", "</chat>"); //the XML I showed you

for($i = 0, $size = count($chats); $i < $size; ++$i) {
//for every chat:
    $all_sms = GBA($chats[$i], "<sms>", "</sms>");
    $name = GB($chats[$i], "<contact>", "</contact>");
    echo "<center><table border='1' cellpadding='5'><tr><td colspan='3' align='center'>SMS Chat with <i>{$name}</i></td></tr><tr><th>From</th><th>Message</th><th>Sent</th></tr>";

    for($j = 0, $size = count($all_sms); $j < $size; ++$j) {
    //for every sms in each chat
            $from = GB($all_sms[$j], "<from>", "</from>");
            $msg = GB($all_sms[$j], "<msg>", "</msg>");
            $sent = time_since(GB($all_sms[$j], "<sent>", "</sent>"));
            echo "<tr><td>{$from}</td><td>{$msg}</td><td>Sent: {$sent}   </td></tr>";
        }
    echo "</table><br /><br /></center>";
}

Как видите, все выглядит хорошо, но показывает только первые 2 таблицы, а не третью! Я много отладил, но я не сделал вывод.

Ответы [ 2 ]

1 голос
/ 26 июля 2011

Вы использовали $size во внешнем цикле и $size во внутреннем цикле.

PHP не имеет области видимости блока, так что это та же самая переменная . Когда он изменяется во внутреннем цикле, вы запутываете внешний цикл.

Выберите другое имя для переменной во внутреннем цикле.

0 голосов
/ 26 июля 2011

Внутри внутреннего цикла вы переназначаете размер $. Вторая группа SMS-сообщений содержит только 2 записи, что приводит к завершению внешнего цикла, поскольку $ size = 2 и $ i = 2. Предложение Джона Мартина, кажется, работает для ваших конкретных данных, но в общем случае не сработает.

Я предлагаю

for($j = 0, $jsize = count($all_sms); $j < $jsize; ++$j) {
// ...
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...