目次
はじめに
将原始CSV文件转换为数组
使用fgetcsv() ,将CSV文件转换成数组
使用array_map() 读取一个CSV文件
总结
ホームページ バックエンド開発 PHPチュートリアル PHPでCSVコンテンツを読み取り、配列に保存する方法

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

Feb 25, 2022 pm 04:20 PM
php 配列 CSVを読む

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 サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

CakePHP のロギング CakePHP のロギング Sep 10, 2024 pm 05:26 PM

CakePHP へのログインは非常に簡単な作業です。使用する関数は 1 つだけです。 cronjob などのバックグラウンド プロセスのエラー、例外、ユーザー アクティビティ、ユーザーが実行したアクションをログに記録できます。 CakePHP でのデータのログ記録は簡単です。 log()関数が提供されています

See all articles