猫型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でControllerからViewへデータを渡す時の注意点

Controller側で $this->set(‘hensu’,$role); $this->set(‘aaa’,’xxx’); としてやれば、View側で ; ; として値を取り出すこと …

CakePHPでSQLを直接実行する

正直find等を使用するのは面倒です。 SQLを直接実行するには以下のようにします。 $sql=’select count(*) as cnt, referer from acls where con …

CakePHPのlayoutを指定する

ログイン画面ではメニューが不要であったりと、 レイアウトを変更したい場合はコントローラーのアクションで以下のように指定します。 View/Layout/配下に作成したレイアウトを指定すればよいのですが …

CakePHP Viewのラベルを変更する

デフォルトでは列タイトルがそのまま表示されてしまいます。 分かりやすい日本語表示に変更します。 INPUTの場合は以下のようにします。 <div class="companies fo …

asp

IISの設定

Visual StudioでLocalに配置したサイトが、ブラウザで表示できず、下記エラーが表示された場合の対処法です。 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ …