ホームページ >バックエンド開発 >PHPチュートリアル >PHPでCSVコンテンツを読み取り、配列に保存する方法

PHPでCSVコンテンツを読み取り、配列に保存する方法

青灯夜游
青灯夜游転載
2022-02-25 16:20:407809ブラウズ

PHP を使用して CSV を配列に読み取るにはどうすればよいですか?次の記事では、PHP を使用して CSV コンテンツを読み込み、配列に変換する方法を説明します。

PHPでCSVコンテンツを読み取り、配列に保存する方法

この記事では、PHP の組み込み関数を使用して CSV ファイルの内容を読み取って出力し、配列に変換する方法を説明します。 fopen()fgetcsv() を使用して CSV ファイルの内容を読み取り、次に array_map()str_getcsv() を使用します。 関数を使用して配列に変換します。

はじめに

データ ファイルをカンマ区切り値 (CSV) 形式で保存することは、新しいことではありません。実際、CSV ファイルはそのシンプルさからデータを保存する最も一般的な方法の 1 つであり、読み書きが簡単で、基本的なテキスト エディタで開くことができます。このタイプのファイルには、表形式のデータがプレーン テキストで保存されます。

このようなファイルの例は次のとおりです。

Elias,40,nurse
Rehema,15,programmer
Beatrice,23,doctor

このデータは 3 人の人物に関する情報を表しており、名前、年齢、職業に対応する列があります。これは単純なデータ形式ですが、読み取りと利用には注意が必要です。

そこで、この記事では、PHP のネイティブ関数 (fopen() など) を使用して CSV ファイルを開く方法と、fgetcsv()# の使用方法を説明します。 # # このファイルの内容を読み取る方法と、最後に array_map() 関数を使用してこの CSV ファイルを配列に変換する方法です。

もちろん、これらを実現するためにいくつかのサードパーティ ソフトウェア パッケージを使用することもできますが、PHP の組み込みローカル関数は非常に使いやすいです。

前提条件

この記事の学習を続けるには、次の条件が必要です。

始めましょう!

CSV ファイルをテーブルとして表示します

記事のこの部分では、カンマで区切られた複数の単語を含む単純な CSV ファイルを読み取ります。まず、上記の単純なファイルを使用します。その後、ランダムな大きなファイルを引き続き使用できます。もちろん、Microsoft Excel またはテキスト エディタを使用して独自のファイルを作成し、CSV 拡張子を付けて保存することもできます。

ファイルを読み取るには、まずファイルが保存されているフォルダーまたは場所でファイルを見つける必要があります。簡単にアクセスできるように、プログラム ファイルと同じフォルダーに保存するとよいでしょう。次に、

fopen() 関数を使用してファイルを読み取ることができます。

その後、

fgetcsv() 関数は、開いているファイルの解析された行から CSV フィールドをチェックします。この関数は 3 つのパラメータを取ります。fopen() から返されるファイル ハンドル、読み取る行の最大長、および特別な区切り文字 (これを「区切り文字」と呼びます) です。これには、カンマ、セミコロン、またはその他の区切り文字を使用できます。

それでは実際にやってみましょう。

WAMP または XAMPP で提供できる場所に

csvtable.php という名前のファイルを作成し、次のコードをコピーします。

<?php

$file_to_read = fopen(&#39;data.csv&#39;, &#39;r&#39;);

if($file_to_read !== FALSE){
    
    echo "<table>\n";
    while(($data = fgetcsv($file_to_read, 100, &#39;,&#39;)) !== FALSE){
        echo "<tr>";
        for($i = 0; $i < count($data); $i++) {
            echo "<td>".$data[$i]."</td>";
        }
        echo "</tr>\n";
    }
    echo "</table>\n";

    fclose($file_to_read);
}

?>

このファイルでは、まず

data.csv ファイルを開きます。このファイルには、カンマ区切りのデータが含まれています。 fopen は、csvtable.php と同じフォルダーでこのファイルを検索します。 'r' パラメータは、ファイルを読み取り専用モードで開くように fopen に指示します。

ファイルが正常に開かれると、

fopen は他のファイルの読み取り操作に使用できるファイル ハンドルを返します。それ以外の場合は、FALSE を返します。したがって、ファイルの読み取りを続行する前に、ファイル ハンドルが FALSE であるかどうかを確認します。

次に、

fgetcsv() ファイルは、開いているファイルから CSV フィールドを一度に 1 行ずつ取得します。 fgetcsv に、1 行あたり最大 100 文字を読み取り、区切り文字としてカンマ区切り文字を使用するように指示します。ファイル内で見つかった単語はループ処理され、HTML テーブルに出力されます。

最後の関数は

fclose() で、開いているファイルを閉じます。これにより、開いているファイルによって使用されていたメモリが解放され、他のプロセスがファイルにアクセスできるようになります。

WAMP または XAMPP ローカルホスト サーバー経由で

csvtable**.php** を開くか、コマンド ラインから php read.php を実行すると、次の出力が表示されます。 。

PHPでCSVコンテンツを読み取り、配列に保存する方法

実装する必要があることの最初の部分は完了です!

次に、生の CSV フィールドを配列に変換します。

将原始CSV文件转换为数组

现在,有不止一种方法来产生数组。我们可以使用fgetcsv() 函数将CSV文件的内容自动转换为数组,或者我们可以使用array_map

使用fgetcsv() ,将CSV文件转换成数组

这与上面的例子类似,我们使用fgetcsv() ,将一个CSV文件渲染成一个HTML表格。让我们来看看这个动作。创建一个具有以下内容的PHP文件。

<?php
function csvToArray($csvFile){

    $file_to_read = fopen($csvFile, &#39;r&#39;);

    while (!feof($file_to_read) ) {
        $lines[] = fgetcsv($file_to_read, 1000, &#39;,&#39;);

    }

    fclose($file_to_read);
    return $lines;
}

//read the csv file into an array
$csvFile = &#39;data.csv&#39;;
$csv = csvToArray($csvFile);

//render the array with print_r
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($csv);
echo &#39;
'; ?>

在上面的代码中,我们创建了一个函数来读取一个CSV文件并将其转换为数组。我们传入一个参数,包含CSV文件的名称和路径。

然后,我们使用feof() 函数来检查是否已经到达文件的末端。在到达之前,我们需要使用fgetcsv() 函数解析CSV字段,就像我们在上面的例子中做的那样。

使用fgetcsv() 函数将CSV文件中被解析的CSV字段转换为数组,并将其逐一追加到$lines[] 变量中。

最后,别忘了在退出函数之前,使用fclose() 函数关闭已打开的文件。

然后,我们调用readDocument 函数,该函数将CSV文件作为参数传递,接下来,CSV文件的内容将显示如下。

PHPでCSVコンテンツを読み取り、配列に保存する方法

使用array_map() 读取一个CSV文件

另外,你也可以使用array_map() 函数将一个CSV文件读入一个数组。要做到这一点,你要使用str_getcsv 作为回调函数。这是一个内置的PHP函数,用来解析一个CSV字符串到一个数组中。

回调函数是一些可执行的代码,它作为一个参数传递给另一段代码。这个参数预计在以后会被传递给它的代码回调。

下面是我们如何使用array_mapstr_getcsv ,将我们的CSV数据映射成一个数组。

<?php
$csv = array_map(&#39;str_getcsv&#39;, file(&#39;data.csv&#39;));
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
print_r($csv);
echo &#39;
'; ?>

上面的代码使用file() 方法将CSV文件读成一个行数组。然后,通过数组映射,它在每一行上调用str_getcsv() ,并将整个文件的数据存储在$csvstr_getcsv() 函数将每一行的CSV字段内容解析为一个数组。

上述代码片断的输出将与上述相同。

注意到在直接使用file()array_map() 函数时,需要的代码少了很多吗?

总结

在这篇文章中,你学到了如何在PHP中处理一个CSV文件,通过使用PHP本地函数如fopen()fgetcsv() 读取和显示其内容,并将CSV字段转换为数组。我向你展示了两种方法。

现在,试着自己做吧。编码愉快!

相关文章推荐:php文件操作系列大汇总(持续更新~)

推荐学习:《PHP视频教程》、《PHP ARRAY

以上がPHPでCSVコンテンツを読み取り、配列に保存する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.cnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。