ホームページ >バックエンド開発 >PHPチュートリアル >phpで読み込んだcsvファイルのデータが不完全になる問題を解決する fgetcsv_PHPチュートリアル
phpではfgetcsv関数でcsvファイルを読み込んでいますが、php5.2.8版のLinuxではfgetcsvで読み込んだcsvファイルのデータが不完全であることが判明する問題の解決策を見てみましょう。
他のバージョンの Windows の場合
コードは次のとおりです | コードをコピー |
# ファイルを開きます。
if (($handle = fopen("test.csv", "r")) !== FALSE) { |
解決策はカスタム関数を使用することです
コードは次のとおりです
コードをコピー
function __fgetcsv(& $handle, $length = null, $d = ',', $e = '"') { | $d = preg_quote($d); $e = preg_quote($e); $_line = ""$eof=false | While ($eof != true) {
$_csv_line = preg_replace('/(?: |[ ])?$/', $d, トリム($_line));
$_csv_pattern = '/(' . $e . '[^' . $e . ']*(?:' . $e . $e . '[^' . $e . ']*)*' . $e . '|[^' . ']*) ' .
Preg_match_all($_csv_pattern, $_csv_line, $_csv_matches);
$_csv_data = $_csv_matches[1] ;
for ($_csv_i = 0; $_csv_i < count($_csv_data); $_csv_i++) { |