|
|
|
| Пытаюсь разделить строку с помощью wordwrap(), но делит неправильно!
Пытаясь понять в чем дело, прошел по буквам функцией ord(), где заметил, что текст содержит символы ASCII 208, 209 и 178. После того, как эти символы были удалены с помощью str_ireplace() с текстом начались глюки, тоесть текст вообще ни как не похож на чтиво - сплошные иероглифы.
wordwrap() видит эти символы и делит строку учитывая эти символы, что визуально не выглядит стабильно, а соответственно не правильно!
Задача вот в чем: нужно поделить строку если она превышает 20 знаков
p.s. Кодировка utf-8
Возможно это только где русский (не точно)
Возможное возникновение проблемы в iconv из виндовс-1251 в утф-8 | |
|
|
|
|
|
|
|
для: solonifer
(15.08.2007 в 08:44)
| | UTF-8 - многобайтовая кодировка. Кириллица представлена двумя байтами.
Попробуйте настроить локаль с помощью setlocale(), либо сначала переводите, допустим, в windows-1251 с помощью iconv() или mb_convert_encoding(), применяйте wordwrap(), а после назад в UTF-8, либо надо писать собственную функцию wordwrap() для UTF-8. | |
|
|
|
|
|
|
|
для: solonifer
(15.08.2007 в 08:44)
| | для работы с символьными данными в utf-8 следует применять функции семейства mb_... Обычные функции str_... и иже с ними неприменимы - они работают только с байтами. | |
|
|
|
|
|
|
|
для: Trianon
(15.08.2007 в 19:19)
| | А байты 208 и 209-это как раз и есть первые байты русских символов...Убив их,вы убили всю строку | |
|
|
|