Я использую WAMP. Мне нужно прочитать содержимое документа Word из папки загрузки на сервере. Документ Word содержит заголовки, содержащие стиль заголовка (заголовок 1) и параграфы. Приведенная ниже функция преобразует документ в читаемый текст, и я сохраняю Результат этой функции в переменной, скажем, $result
;
private function read_docx(){
$striped_content = '';
$content = '';
$zip = zip_open($this->filename);
if (!$zip || is_numeric($zip)) return false;
while ($zip_entry = zip_read($zip)) {
if (zip_entry_open($zip, $zip_entry) == FALSE) continue;
if (zip_entry_name($zip_entry) != "word/document.xml") continue;
$content .= zip_entry_read($zip_entry, zip_entry_filesize($zip_entry));
zip_entry_close($zip_entry);
}// end while
zip_close($zip);
$content = str_replace('</w:r></w:p></w:tc><w:tc>', " ", $content);
$content = str_replace('</w:r></w:p>', "\r\n", $content);
$striped_content = strip_tags($content);
return $striped_content;
}
Я ставлю <h1></h1>
теги вокруг заголовков и <p></p>
теги вокруг абзацев в текстовом документе.
Я хочу разделить строку $ wordread, используя функцию strtok, как указано ниже
$tok = strtok( $wordread, "<p>");
while ($tok !== false) {
echo "Word=$tok<br />";
$tok = strtok("<p>");
}
Например, у меня есть файл слов, который содержит <p>this is paragraph</p>
, Я хочу извлечь «это абзац», чтобы получить все абзацы и заголовки в двух разных массивах.
Задача ещё не решена.
Других решений пока нет …