Я экспортирую содержимое из базы данных MySQL в шаблон Word (RTF) через PHP.Записи не зацикливаются в экспортированном документе RTF
Существует раздел «Приложение B», в котором должны отображаться все найденные сокращения для записи. Минимальные записи для этого раздела - 90 (т. Е. Это стандартные аббревиатуры (tblAcronyms), которые будут иметь каждая запись); однако максимальные записи неизвестны, так как пользователи могут добавить к этому списку (tblAppendixB).
Документ Word (т. Е. RTF) должен отображать все найденные записи, однако он отображает только первую запись.
Это то, что я до сих пор:
<?php
....
#Retrieve Appendix B records
$qry_get_AppB = "SELECT vAcronym, vAcronymDesc FROM tblAcronyms
UNION SELECT vAcronym, vAcronymDesc FROM tblAppendixB
WHERE fkID = ". $i_fk_id . " ORDER BY vAcronym ASC";
$qry_appb_result = mysql_query($qry_get_AppB);
$qryAppBno_rows = mysql_num_rows($qry_appb_result);
//Generate the headers to help a browser choose the correct location
header('Content-Type: application/msword');
header('Content-Disposition: inline; filename="'.$vProgramName.'_rec.rtf");
//Open the template file
$tfilename = 'Appb_Template.rtf';
$fp = fopen($tfilename, 'r');
//Read the template into a variable
$toutput = fread($fp, filesize($tfilename));
fclose($fp);
//Replace the place holders in the template with data
if($qryAppBno_rows > 0)
{
while($rowAppB = mysql_fetch_array($qry_appb_result))
{
$vAppB = $rowAppB['vAcronym'] . '-' . $rowAppB['vAcronymDesc'] . "\r\n";
$toutput = str_replace('<<vAppB>>', $vAppB, $toutput);
}
}
//Send the generated document to the browser
echo $toutput;
?>
Я искал этот форум и другие, но до сих пор найти решение.
Любая помощь очень ценится.
Благодарим за предоставленную мне идею о том, как решить мою проблему. Когда я повторяю переменную, я получаю все записи (т. Е. Собираю все записи, что хорошо); поэтому я попытался создать другую переменную, которая затем сохранит эти значения (т. е. $ appendix_result = $ appendix), а затем выполнит $ toutput = str_replace ('>', $ appendix_result, $ toutput); но это тоже не сработало. Был ли я на правильном пути, что вы предложили ??? –
Nicole
Ooops ... должен читать @Zip ... Спасибо, что дал мне .... (Извините) – Nicole
Я внес некоторые изменения ... теперь он собирает все записи и экспортирует их в шаблон Word, однако он не нарушает (т.е. вставляет новый разрыв строки); контент работает вместе. Это то, что у меня есть .... while ($ rowAppB = mysql_fetch_array ($ qry_appb_result)) { $ vAppendixB [] = $ rowAppB ['vAcronym']. '-'. $ rowAppB ['vAcronymDesc']. $ T_newline; $ vAppB = implode ($ t_newline, $ vAppendixB); } $ toutput = str_replace ('<>', $ vAppB, $ toutput); Я знаю, что я рядом, но не могу понять, чего я не вижу. Опять же, любая помощь с большой благодарностью. –
Nicole