Unicode — количество слов в php .doc, .docx с греческими символами

Я строю веб-приложение, используя php, и мне нужно посчитать слова загруженного файла .doc или .docx.
До сих пор я использовал вышеупомянутые функции для подсчета слов, но этот код не работает для греческих символов

для .doc

 public static function docWordCount($file){
$fileHandle = fopen($file, "r");
$line = @fread($fileHandle, filesize($file));
$lines = explode(chr(0x0D),$line);
$outtext = "";
foreach($lines as $thisline)
{
$pos = strpos($thisline, chr(0x00));
if (($pos !== FALSE)||(strlen($thisline)==0))
{
} else {
$outtext .= $thisline." ";
}
}
$outtext = preg_replace("/[^a-zA-Z0-9\s\,\.\-\n\r\t@\/\_\(\)]/","",$outtext);
return str_word_count($outtext);
}

и для .docx:

  public static function docxWordCount($file){
$striped_content = '';
$content = '';

$zip = zip_open($file);

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 str_word_count($striped_content);
}

0

Решение

str_word_count не кажется бинарно-безопасным, то есть не поддерживает символы UTF-8. Ваш лучший выбор — использовать preg_match разделить текст на несловесные символы, используя \P{L} имущество. Например, следующее регулярное выражение разделит ваш текст на каждый не буквенный символ:

preg_split('/\P{L}/usi', $str, -1, , PREG_SPLIT_DELIM_CAPTURE | PREG_SPLIT_NO_EMPTY);

Увидеть Свойства символов Юникода для дополнительной информации

-1

Другие решения

Других решений пока нет …