PHP4.xxでSQLIte3で行っています。
名簿をCSVデータで一気にDBにインサートしたいのですが・・・
なぜか名前の1~2文字目あたりのみ文字化けします。
色々試行錯誤していますが・・・
糸口が見つからなくて・・・
どなかたかご教授して頂けませんか?!
文字化け具合(というよりアルファベットに変わってる)が画像を参照してください。
CSVデータでは、山崎まさよし、abc、岡田てるお
となっています。
ちなみにコードはこのような形です。
--------------------------------------------------------
$updir = "./csv/";
$save_name = "list.csv";
if (is_uploaded_file($_FILES["csv"]["tmp_name"])) {
if (move_uploaded_file($_FILES["csv"]["tmp_name"], $updir.$save_name)) {
chmod($updir.$save_name, 0644);
echo "<br />CSVファイルをアップロードしました。";
// CSVの各内容をインサート
$row = 1;
$handle = fopen($updir.$save_name, "r");
while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
$num = count($data);
$insert = "insert into list values (";
$insert_row = "";
$row++;
for ($c=0; $c < $num; $c++) {
$data[$c] = mb_convert_encoding($data[$c], "EUC-JP", "SJIS");
$insert_row .= "'".$data[$c]. "',\n";
}
$insert_query = $insert.$insert_row;
$insert_query = substr($insert_query, 0, (strlen($insert_query)-2) );
$insert_query .= ")";
if(sqlite_query($insert_query, $conn)){
} else {
echo "<br>配信先情報の追加を失敗しました。";
}
}
}
}
fclose($handle);
--------------------------------------------------------
No.1ベストアンサー
- 回答日時:
EUC-JPで保存しようとしていますね。
SQLiteはUTF-8で保存した方がいいので、
$data[$c] = mb_convert_encoding($data[$c], "UTF-8", "SJIS");
とします。
読み込みはEUC-JPで行っているようですから、出力時に
$data = mb_convert_encoding($data, "EUC-JP", "UTF-8");
でEUCに戻すか、プロジェクト全体の文字コードをUTF-8にしましょう。
まだ、書き始めだと思うので、プロジェクト全体をUTF-8に
することをお勧めします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
CSVファイルの最終行のデー...
-
PHPで、CSVファイルを、指定し...
-
Resource id #3 と表示されま...
-
preg_splitがうまくいかないの...
-
PHP: 未定義エラーの回避方法を...
-
配列をループでたくさん宣言し...
-
CArrayの要素としてCStringArra...
-
STLのvectorで作った配列をメン...
-
マッチング処理(1:N)
-
String だと「 ByRef引数の型が...
-
POSTで渡されるデータの数がわ...
-
pythonのnumpyでの繰り返しでの...
-
2次元配列の値の受け渡しについ...
-
配列一致(要素順番は違うが内容...
-
PHPの preg_grep関数(正規表現...
-
PHPとMySQLの高速化
-
PHPのループ数限界値について
-
charのポインタについて
-
php 省略可能な引数配列を持つ...
-
割り切れなくなるまで分割して...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Resource id #3 と表示されま...
-
別ファイルの構造体の値を読み...
-
CSVファイルの最終行のデー...
-
stdClass Objectを連想配列のよ...
-
複数行のデータのPOST処理に関して
-
CSVでアップロードしたデータの...
-
自動で番号を振りたい
-
C言語でCSVファイルの行数を読...
-
ヒアドキュメントの中のfor文
-
FortranのOPEN文
-
行数が30万件ほどあるCSVから、...
-
バイナリファイルの内容を、そ...
-
消費者物価指数
-
エラーメッセージ(無効な間接...
-
rubyで複数列のデータを一行に...
-
CSVデータの行数カウントをした...
-
csvの内容を行単位で削除したい
-
VBAでcsvファイルもシートもあ...
-
preg_splitがうまくいかないの...
-
文字列の文字一文字ずつを解析...
おすすめ情報