猫型iPS細胞研究所

Windows、Linux、iOS、DB、Network

未分類

PHPでCSVの読み込みにマルチバイトを使用する

投稿日:

csvを読み込もうとするとどうしてもマルチバイトが文字化けしてしまいました。

array(
	(int) 0 => 'XXXXXXXXX',
	(int) 1 => 'eストメッセージ http://yahoo.co.jp'
)

このようにテストがeストとなってしまいます。

mbstringのインストール

PHPではマルチバイトを使用するにはmbstinrgをインストールする必要があります。

[root@centos app]# yum install php-mbstring

php.iniの修正

以下を確認します。

[root@centos app]# vim /etc/php.ini
[mbstring]
mbstring.language = Japanese
mbstring.internal_encoding = UTF-8
mbstring.http_input = auto
mbstring.http_output = UTF-8
mbstring.encoding_translation = Off
mbstring.detect_order = auto

CSVファイルの読み込みには更に注意が必用

setlocaleを入れるfgetcsvの前に入れましょう。

$tmp = fopen($uploadfile, "r");
setlocale(LC_ALL, 'ja_JP');
while ($csv = fgetcsv($tmp)) {
・・・

Gooleアドセンス用336

Gooleアドセンス用336

-未分類
-

執筆者:

関連記事

CakePHPのauth.phpでパスワードの認証ができない

Usersテーブルにusernameとpasswordを入れて、 チュートリアルにある簡単な認証画面でテストしたのですが、 どうしても認証できません。 データベースはMySQLを使用して、select …

CakePHP Appcontrollerで設定した変数を別のcontrollerで参照する

AppControllerで $this->set(‘custcode’,$cust_code); として企業コードを$custcodeにセットしたとします。 Viewから参照するには以下のよう …

「Cookie」と「セッション」と「セッションCookie」の違い

セッションという日本語のイメージこそ、最も注意すべき点です。 WEBサーバーとブラウザの間には、トンネルのような物理的な接続状態は存在しません。 一回ポッキリのデータのリクエスト・レスポンスしかHTT …

CakePHP findでMySQL関数を使用したい

たとえばMySQLのconcatを使用して文字列を結合したいとします。 $data = $this->Company->find(‘list’, array( ‘fields’=>a …

CakePHPのpaginateのまとめ

joinした列でソートする ソートというのはViewの列名をクリックしてするソートではなく、 ControllerでのSQLのソートです。 virtualFieldsをMoldeに設定します。 ‘Cs …