PHP, в то время как цикл и заголовок таблицы только показывают, если установлено значение db - PullRequest
0 голосов
/ 24 июня 2010

Вот мой код.

<table border="1" style="width:800px">
                <?php $schedule_db = mysql_query("SELECT * FROM schedule WHERE '00:00' is not null and '01:00' is not null and '02:00' is not null and '03:00' is not null and '04:00' is not null and '05:00' is not null and '06:00' is not null and '07:00' is not null and '08:00' is not null and '09:00' is not null and '10:00' is not null and '11:00' is not null and '12:00' is not null and '13:00' is not null and '14:00' is not null and '15:00' is not null and '16:00' is not null and '17:00' is not null and '18:00' is not null and '19:00' is not null and '20:00' is not null and '21:00' is not null and '22:00' is not null and '23:00' is not null") 
                or die(mysql_error()); ?>
                <form method="post" action="config_action.php">
                <?php while($schedule = mysql_fetch_array( $schedule_db )) { ?>
                    <tr><?php if(isset($schedule['00:00'])) { ?><td style="width:32px"><?php echo $schedule['00:00'] ?></td><?php } if(isset($schedule['02:00'])) { ?><td style="width:32px"><?php echo $schedule['02:00'] ?></td><?php } if(isset($schedule['03:00'])) { ?><td style="width:32px"><?php echo $schedule['03:00'] ?></td><?php } if(isset($schedule['04:00'])) { ?><td style="width:32px"><?php echo $schedule['04:00'] ?></td><?php } if(isset($schedule['05:00'])) { ?><td style="width:32px"><?php echo $schedule['05:00'] ?></td><?php } if(isset($schedule['06:00'])) { ?><td style="width:32px"><?php echo $schedule['06:00'] ?></td><?php } if(isset($schedule['07:00'])) { ?><td style="width:32px"><?php echo $schedule['07:00'] ?></td><?php } if(isset($schedule['08:00'])) { ?><td style="width:32px"><?php echo $schedule['08:00'] ?></td><?php } if(isset($schedule['09:00'])) { ?><td style="width:32px"><?php echo $schedule['09:00'] ?></td><?php } if(isset($schedule['10:00'])) { ?><td style="width:32px"><?php echo $schedule['10:00'] ?></td><?php } if(isset($schedule['11:00'])) { ?><td style="width:32px"><?php echo $schedule['11:00'] ?></td><?php } if(isset($schedule['12:00'])) { ?><td style="width:32px"><?php echo $schedule['12:00'] ?></td><?php } if(isset($schedule['13:00'])) { ?><td style="width:32px"><?php echo $schedule['13:00'] ?></td><?php } if(isset($schedule['14:00'])) { ?><td style="width:32px"><?php echo $schedule['14:00'] ?></td><?php } if(isset($schedule['15:00'])) { ?><td style="width:32px"><?php echo $schedule['15:00'] ?></td><?php } if(isset($schedule['16:00'])) { ?><td style="width:32px"><?php echo $schedule['16:00'] ?></td><?php } if(isset($schedule['17:00'])) { ?><td style="width:32px"><?php echo $schedule['18:00'] ?></td><?php } if(isset($schedule['19:00'])) { ?><td style="width:32px"><?php echo $schedule['19:00'] ?></td><?php } if(isset($schedule['20:00'])) { ?><td style="width:32px"><?php echo $schedule['20:00'] ?></td><?php } if(isset($schedule['21:00'])) { ?><td style="width:32px"><?php echo $schedule['21:00'] ?></td><?php } if(isset($schedule['22:00'])) { ?><td style="width:32px"><?php echo $schedule['22:00'] ?></td><?php } if(isset($schedule['23:00'])) { ?><td style="width:32px"><?php echo $schedule['23:00'] ?></td><?php } ?></tr>
                <?php } ?>
                </form>
</table>

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

Я думал, что кодирую что-то вроде:

<tr><?php if(isset($schedule['00:00'])) { ?><td style="width:32px">00:00</td><?php } if(isset($schedule['01:00'])) { ?><td style="width:32px">01:00</td><?php } ?> etc.

Однако, поскольку он находится в цикле while, он будет происходить перед каждой фактической строкой, которая не являетсячто я хочу, чтобы это случилось, я просто хочу, чтобы это случилось один раз на вершине.

Как я могу решить эту проблему?Есть ли что-то, что я мог бы добавить к этому, чтобы сделать цикл только один раз?

Спасибо!

1 Ответ

1 голос
/ 24 июня 2010

Тогда не выводите свои строки в цикле while.Сохраните все данные в var.И затем, если переменная содержит содержимое, выведите заголовок, а после этого переменную, содержащую все строки содержимого.

РЕДАКТИРОВАТЬ

Хорошо, это самый уродливый код, который я когда-либо писал, вы могли бы использовать массивы и прочее, чтобы сделать код намного меньше.Но это фрагмент кода, чтобы понять ... Захватить все строки.При этом проверяйте каждое поле, если оно заполнено. Если это так, то вам понадобится столбец для этого в заголовке.Мы делаем это, устанавливая data0, например, true.После обработки всех данных мы проверяем каждую переменную и смотрим, правда ли это.Если так, то вы печатаете столбец в заголовке.Итак, в конце вы видите, что вы выводите табличный тег, затем headrow-var, затем строку со всеми форматированными данными и затем закрывающий табличный тег.Итак, вы получите основную идею.Храните заголовок и другие ряды в отдельных переменных и размещайте их в правильном порядке ...

// Get data from database-table...
$schedule_db = mysql_query('...your query...') or die(mysql_error());

$data0 = false;
$data1 = false;
$data2 = false;
// reapeat this for all hours till 23...

while($schedule = mysql_fetch_array($schedule_db))
{
    if(isset($schedule['00:00']))
    {
        $data0 = true;
        $row = '<td style="width: 32px;">' . $schedule['00:00'] . '</td>';
    }

    // Reapeat this for every hour you need...
    if(isset($schedule['01:00']))
    {
        $data1 = true;
        $row .= '<td style="width: 32px;">' . $schedule['01:00'] . '</td>';
    }

    //...

    $rows .= $row;
}

$headrow = '<tr>';
if($data0 === true)
    $headrow .= '<th>00:00</th>' 

if($data1 === true)
    $headrow .= '<th>01:00</th>';

// Repeat for all hours...


$headrow = '</tr>';

echo '<table>';
echo $headrow;
echo $rows;
echo '</table>';
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...