質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

Q&A

解決済

1回答

709閲覧

php Laravel csv文字コード変換について

yoheiiii

総合スコア87

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

文字コード

文字コードとは、文字や記号をコンピュータ上で使用するために用いられるバイト表現を指します。

0グッド

0クリップ

投稿2023/05/22 05:23

編集2023/05/22 05:39

実現したいこと

ヘッダーなしで、文字コード:Shift_JISでCSVを保存したい。

前提

ヘッダーをつけてCSVを作成保存しました。
その時はShift_JISでCSVを保存できていました。
ヘッダーがいらなくなりヘッダー無で保存すると
UTF-8で保存されてしまいます。
確認方法はCSVをメモ帳で開きUTF-8と表示されていました。

該当のソースコード

if (isset($completedata)) { // $head = ['顧客ID', 'カード番号', 'カード有効期限']; $f = fopen("storage/app/$completefile_name", 'w'); if ($f) { // カラムの書き込み // mb_convert_variables('Shift_JIS', 'UTF-8', $head); // fputcsv($f, $head); // データの書き込み foreach ($completedata as $val) { mb_convert_variables('Shift_JIS', 'UTF-8', $val); fputcsv($f, $val); } } // ファイルを閉じる fclose($f);

試したこと

ヘッダーを付けた状態はShift_JISだったので
一度作ってからヘッダー削除してみましたが
結果は同じでした。

$arr = file("storage/app/$completefile_name"); array_shift($arr); Storage::disk('local')->put($completefile_name, $arr);

補足情報(FW/ツールのバージョンなど)

PHP 7.2.34
Laravel Framework 6.20.44

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tanat

2023/05/22 05:35

> ヘッダーがいらなくなりヘッダー無で保存するとUTF-8で保存されてしまいます。 保存されたCSVの文字コードがUTF-8であることをどのように確認したかについて質問に追記をお願いします。
yoheiiii

2023/05/22 05:39

追記させて頂きました。
guest

回答1

0

ベストアンサー

確認方法はCSVをメモ帳で開きUTF-8と表示されていました。

おそらく、ヘッダ以外の行には半角英数字しか存在しないデータなのだと思います。
半角英数字のみで構成されているファイルの文字コードはSJISとUTF-8を仕様上区別することが出来ないので、メモ帳はデフォルトであるUTF-8と判定しているだけだと思われます。

この場合、生成されているファイルはSJISかつUTF-8のCSVファイルとなるため、SJISとして扱っても問題の無いファイルとなります。


sjis utf-8 区別できない 半角英数字
あたりをキーワードにして検索してみると、仕様と背景が理解出来るかと思います。

投稿2023/05/22 05:51

編集2023/05/22 05:54
tanat

総合スコア18713

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問