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で質問しましょう!
似たような質問が見つかりました
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
- PHP if(preg_match("/[^0-9]/",$gu_d)){意味を教えてください。 1 2022/05/06 05:37
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- PHP htmlspecialcharsが機能していないです。 バグですか? 1 2022/04/05 01:22
- PHP プログラムコードを入力する場合改行してもいいですか? 2 2022/10/02 16:05
- CGI htmlからパラメータで、cgiに渡したい。 1 2023/02/06 16:15
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- PHP php エラー 2 2022/10/23 16:43
- PHP PHPで画像の渡しが上手く行きません。 1 2023/02/02 09:39
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
別ファイルの構造体の値を読み...
-
ヒアドキュメントの中のfor文
-
PHP5でCSVの指定行データだけを...
-
テキストデータから指定行の削除
-
複数行のデータのPOST処理に関して
-
FortranのOPEN文
-
$_SESSIONに二次元配列を使える...
-
特定の文からメールアドレスの...
-
行列
-
CArrayの要素としてCStringArra...
-
プルダウンメニューにDBの内容...
-
String だと「 ByRef引数の型が...
-
漢字のソートについて
-
マッチング処理(1:N)
-
foreachのなかで次のキーを参照...
-
多次元配列の扱い方
-
php で1から100までの素数の表...
-
foreachの値をメール本文に表示...
-
プログラミングのPythonのnoteb...
-
phpでforeachの中にforeachがあ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
別ファイルの構造体の値を読み...
-
複数行のデータのPOST処理に関して
-
エラーメッセージ(無効な間接...
-
ヒアドキュメントの中のfor文
-
Resource id #3 と表示されま...
-
自動で番号を振りたい
-
C言語でCSVファイルの行数を読...
-
配列同士の足し算のループ処理
-
stdClass Objectを連想配列のよ...
-
PHPでCSVの一部の行を編集したい
-
phpを実行するとファイルダウン...
-
行数が30万件ほどあるCSVから、...
-
phpでCSVファイルの中身を多次...
-
php Undefined variableエラー
-
CSVデータの行数カウントをした...
-
複数ファイルで、それぞれの行...
-
csvの内容を行単位で削除したい
-
CSVファイルの最終行のデー...
-
PHP SimpleXml unsetについて
-
PHP5でCSVの指定行データだけを...
おすすめ情報