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 ファイルを配列に変換する方法です。
fopen() 関数を使用してファイルを読み取ることができます。
fgetcsv() 関数は、開いているファイルの解析された行から CSV フィールドをチェックします。この関数は 3 つのパラメータを取ります。
fopen() から返されるファイル ハンドル、読み取る行の最大長、および特別な区切り文字 (これを「区切り文字」と呼びます) です。これには、カンマ、セミコロン、またはその他の区切り文字を使用できます。
csvtable.php という名前のファイルを作成し、次のコードをコピーします。
<?php $file_to_read = fopen('data.csv', 'r'); if($file_to_read !== FALSE){ echo "<table>\n"; while(($data = fgetcsv($file_to_read, 100, ',')) !== 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() で、開いているファイルを閉じます。これにより、開いているファイルによって使用されていたメモリが解放され、他のプロセスがファイルにアクセスできるようになります。
csvtable**.php** を開くか、コマンド ラインから php read.php を実行すると、次の出力が表示されます。 。
将原始CSV文件转换为数组
现在,有不止一种方法来产生数组。我们可以使用fgetcsv()
函数将CSV文件的内容自动转换为数组,或者我们可以使用array_map
。
使用fgetcsv()
,将CSV文件转换成数组
这与上面的例子类似,我们使用fgetcsv()
,将一个CSV文件渲染成一个HTML表格。让我们来看看这个动作。创建一个具有以下内容的PHP文件。
<?php function csvToArray($csvFile){ $file_to_read = fopen($csvFile, 'r'); while (!feof($file_to_read) ) { $lines[] = fgetcsv($file_to_read, 1000, ','); } fclose($file_to_read); return $lines; } //read the csv file into an array $csvFile = 'data.csv'; $csv = csvToArray($csvFile); //render the array with print_r echo '<pre class="brush:php;toolbar:false">'; print_r($csv); echo '
在上面的代码中,我们创建了一个函数来读取一个CSV文件并将其转换为数组。我们传入一个参数,包含CSV文件的名称和路径。
然后,我们使用feof()
函数来检查是否已经到达文件的末端。在到达之前,我们需要使用fgetcsv()
函数解析CSV字段,就像我们在上面的例子中做的那样。
使用fgetcsv()
函数将CSV文件中被解析的CSV字段转换为数组,并将其逐一追加到$lines[]
变量中。
最后,别忘了在退出函数之前,使用fclose()
函数关闭已打开的文件。
然后,我们调用readDocument
函数,该函数将CSV文件作为参数传递,接下来,CSV文件的内容将显示如下。
使用array_map()
读取一个CSV文件
另外,你也可以使用array_map()
函数将一个CSV文件读入一个数组。要做到这一点,你要使用str_getcsv
作为回调函数。这是一个内置的PHP函数,用来解析一个CSV字符串到一个数组中。
回调函数是一些可执行的代码,它作为一个参数传递给另一段代码。这个参数预计在以后会被传递给它的代码回调。
下面是我们如何使用array_map
和str_getcsv
,将我们的CSV数据映射成一个数组。
<?php $csv = array_map('str_getcsv', file('data.csv')); echo '<pre class="brush:php;toolbar:false">'; print_r($csv); echo '
上面的代码使用file()
方法将CSV文件读成一个行数组。然后,通过数组映射,它在每一行上调用str_getcsv()
,并将整个文件的数据存储在$csv
。str_getcsv()
函数将每一行的CSV字段内容解析为一个数组。
上述代码片断的输出将与上述相同。
注意到在直接使用file()
和array_map()
函数时,需要的代码少了很多吗?
总结
在这篇文章中,你学到了如何在PHP中处理一个CSV文件,通过使用PHP本地函数如fopen()
和fgetcsv()
读取和显示其内容,并将CSV字段转换为数组。我向你展示了两种方法。
现在,试着自己做吧。编码愉快!
相关文章推荐:php文件操作系列大汇总(持续更新~)
以上がPHPでCSVコンテンツを読み取り、配列に保存する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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