PHP « Как вывести данные из разных файлов в одну таблицу?
Привет! Подскажите, пожалуйста, как свести данные из БД и двух текстовых файлов в одну таблицу?
Количество строк одинаково как в таблице БД, так и в txt файлах. Файлы имеют структуру вида:
1|5
2|3
3|2
.....
Из бд я вывел, а как в этот цикл включить вывод txt?
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
Количество строк одинаково как в таблице БД, так и в txt файлах. Файлы имеют структуру вида:
1|5
2|3
3|2
.....
Из бд я вывел, а как в этот цикл включить вывод txt?
/** * GeSHi (C) 2004 - 2007 Nigel McNie, 2007 - 2008 Benny Baumann * (http://qbnz.com/highlighter/ and http://geshi.org/) */ .php.geshi_code {font-family:monospace;} .php.geshi_code .imp {font-weight: bold; color: red;} .php.geshi_code .kw1 {color: #b1b100;} .php.geshi_code .kw2 {color: #000000; font-weight: bold;} .php.geshi_code .kw3 {color: #990000;} .php.geshi_code .co1 {color: #666666; font-style: italic;} .php.geshi_code .co2 {color: #666666; font-style: italic;} .php.geshi_code .co3 {color: #0000cc; font-style: italic;} .php.geshi_code .co4 {color: #009933; font-style: italic;} .php.geshi_code .coMULTI {color: #666666; font-style: italic;} .php.geshi_code .es0 {color: #000099; font-weight: bold;} .php.geshi_code .es1 {color: #000099; font-weight: bold;} .php.geshi_code .es2 {color: #660099; font-weight: bold;} .php.geshi_code .es3 {color: #660099; font-weight: bold;} .php.geshi_code .es4 {color: #006699; font-weight: bold;} .php.geshi_code .es5 {color: #006699; font-weight: bold; font-style: italic;} .php.geshi_code .es6 {color: #009933; font-weight: bold;} .php.geshi_code .es_h {color: #000099; font-weight: bold;} .php.geshi_code .br0 {color: #009900;} .php.geshi_code .sy0 {color: #339933;} .php.geshi_code .sy1 {color: #000000; font-weight: bold;} .php.geshi_code .st0 {color: #0000ff;} .php.geshi_code .st_h {color: #0000ff;} .php.geshi_code .nu0 {color: #cc66cc;} .php.geshi_code .nu8 {color: #208080;} .php.geshi_code .nu12 {color: #208080;} .php.geshi_code .nu19 {color:#800080;} .php.geshi_code .me1 {color: #004000;} .php.geshi_code .me2 {color: #004000;} .php.geshi_code .re0 {color: #000088;} .php.geshi_code span.xtra { display:block; }
// Выбираем данные из БД
$qsel=mysql_query("SELECT `qid`, `qtext` from `questions` ORDER BY `qid`");
// Открываем первый файл
$key1=fopen("data/test_1_key1.txt", "r");
$k1=explode("/r/n", $key1);
// Открываем второй файл
$key2=fopen("data/test_1_key2.txt", "r");
$k2=explode("/r/n", $key2);
$rtable='<table border="1" cellspacing="0" cellpadding="3">
<tr>
<th width="40%">Вопрос</th>
<th width="20%">Ключ 1</th>
<th width="20%">Ключ 2</th>
<th width="20%">ИМЯРЕК</th>
</tr>';
while($q=mysql_fetch_row($qsel))
{
$rtable.='<tr><td><b>'.$q['1'].'</b></td>';
$rtable.='<td>ДАННЫЕ из 1 файла</td>';
$rtable.='<td>ДАННЫЕ из 2 файла</td>';
$rtable.='<td></td>';
}
echo '</table>'.$rtable;
$qsel=mysql_query("SELECT `qid`, `qtext` from `questions` ORDER BY `qid`");
// Открываем первый файл
$key1=fopen("data/test_1_key1.txt", "r");
$k1=explode("/r/n", $key1);
// Открываем второй файл
$key2=fopen("data/test_1_key2.txt", "r");
$k2=explode("/r/n", $key2);
$rtable='<table border="1" cellspacing="0" cellpadding="3">
<tr>
<th width="40%">Вопрос</th>
<th width="20%">Ключ 1</th>
<th width="20%">Ключ 2</th>
<th width="20%">ИМЯРЕК</th>
</tr>';
while($q=mysql_fetch_row($qsel))
{
$rtable.='<tr><td><b>'.$q['1'].'</b></td>';
$rtable.='<td>ДАННЫЕ из 1 файла</td>';
$rtable.='<td>ДАННЫЕ из 2 файла</td>';
$rtable.='<td></td>';
}
echo '</table>'.$rtable;
1 ответов
Не самый оптимальный вариант, но работать будет:
// Выбираем данные из БД
$qsel=mysql_query("SELECT `qid`, `qtext` from `questions` ORDER BY `qid`");
// Открываем первый файл
$key1=fopen("data/test_1_key1.txt", "r");
$k1=explode("/r/n", $key1);
// Открываем второй файл
$key2=fopen("data/test_1_key2.txt", "r");
$k2=explode("/r/n", $key2);
$data = array();
while($q=mysql_fetch_row($qsel))
{
$fileData1 = explode("|", array_shift($k1)); // выдергиваем строку из начала файла 1
$fileData2 = explode("|", array_shift($k2)); // из файла 2, разбивая из по символу |
$data[] = array(
0 => $q[1], // это строка из базы, берем 2е значение
1 => $fileData1[1], // строка из файла 1, берем 2е значение
2 => $fileData2[1], // строка из файла 2, берем 2е значение
);
}
// данные получены, начинаем вывод
$rtable = '<table border="1" cellspacing="0" cellpadding="3">
<tr>
<th width="40%">Вопрос</th>
<th width="20%">Ключ 1</th>
<th width="20%">Ключ 2</th>
<th width="20%">ИМЯРЕК</th>
</tr>';
foreach ($data as $value) {
$rtable .= '
<tr>
<td>' . $value[0] . '</td>
<td>' . $value[1] . '</td>
<td>' . $value[2] . '</td>
<td> </td>
</tr>
';
}
$rtable .= '</table>';
echo $rtable;
PS: код написан "от руки"
PPS: рекомендую делать проверку на наличие значений в файле, например !empty($fileData1[1])
$qsel=mysql_query("SELECT `qid`, `qtext` from `questions` ORDER BY `qid`");
// Открываем первый файл
$key1=fopen("data/test_1_key1.txt", "r");
$k1=explode("/r/n", $key1);
// Открываем второй файл
$key2=fopen("data/test_1_key2.txt", "r");
$k2=explode("/r/n", $key2);
$data = array();
while($q=mysql_fetch_row($qsel))
{
$fileData1 = explode("|", array_shift($k1)); // выдергиваем строку из начала файла 1
$fileData2 = explode("|", array_shift($k2)); // из файла 2, разбивая из по символу |
$data[] = array(
0 => $q[1], // это строка из базы, берем 2е значение
1 => $fileData1[1], // строка из файла 1, берем 2е значение
2 => $fileData2[1], // строка из файла 2, берем 2е значение
);
}
// данные получены, начинаем вывод
$rtable = '<table border="1" cellspacing="0" cellpadding="3">
<tr>
<th width="40%">Вопрос</th>
<th width="20%">Ключ 1</th>
<th width="20%">Ключ 2</th>
<th width="20%">ИМЯРЕК</th>
</tr>';
foreach ($data as $value) {
$rtable .= '
<tr>
<td>' . $value[0] . '</td>
<td>' . $value[1] . '</td>
<td>' . $value[2] . '</td>
<td> </td>
</tr>
';
}
$rtable .= '</table>';
echo $rtable;
PS: код написан "от руки"
PPS: рекомендую делать проверку на наличие значений в файле, например !empty($fileData1[1])