Как я могу преобразовать текст в формате "Western (Mac OS Roman)" в UTF-8 с помощью PHP? - PullRequest
8 голосов
/ 18 января 2011

У меня есть файлы, экспортируемые Excel для Mac 2011 VBA в Western (Mac OS Roman) , как показано здесь:

alt text

У меня нет* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Я не могу преобразовать эти файлы с помощью PHP прежде, чем я сохраню их в MySQL, .1012 * Я нашел этот список допустимых форматов кодирования с 2008 года, но, похоже, ни один из них не представляет Western (Mac OS Roman).

* UCS-4
* UCS-4BE
* UCS-4LE
* UCS-2
* UCS-2BE
* UCS-2LE
* UTF-32
* UTF-32BE
* UTF-32LE
* UTF-16
* UTF-16BE
* UTF-16LE
* UTF-7
* UTF7-IMAP
* UTF-8
* ASCII
* EUC-JP
* SJIS
* eucJP-win
* SJIS-win
* ISO-2022-JP
* JIS
* ISO-8859-1
* ISO-8859-2
* ISO-8859-3
* ISO-8859-4
* ISO-8859-5
* ISO-8859-6
* ISO-8859-7
* ISO-8859-8
* ISO-8859-9
* ISO-8859-10
* ISO-8859-13
* ISO-8859-14
* ISO-8859-15
* byte2be
* byte2le
* byte4be
* byte4le
* BASE64
* HTML-ENTITIES
* 7bit
* 8bit
* EUC-CN
* CP936
* HZ
* EUC-TW
* CP950
* BIG-5
* EUC-KR
* UHC (CP949)
* ISO-2022-KR
* Windows-1251 (CP1251)
* Windows-1252 (CP1252)
* CP866 (IBM866)
* KOI8-R

Какой формат мне нужно использовать дляконвертировать "Western (Mac OS Roman) в UTF-8?

1 Ответ

20 голосов
/ 18 января 2011

mb-функции не могут обрабатывать «macintosh», которое является определенным IANA именем для Mac Roman.Вы должны использовать iconv.

$line = iconv('macintosh', 'UTF-8', $line);
...