検索
ホームページバックエンド開発PHPチュートリアル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 までご連絡ください。
セッションに関連するクロスサイトスクリプティング(XSS)攻撃からどのように保護できますか?セッションに関連するクロスサイトスクリプティング(XSS)攻撃からどのように保護できますか?Apr 23, 2025 am 12:16 AM

セッション関連のXSS攻撃からアプリケーションを保護するには、次の測定が必要です。1。セッションCookieを保護するためにHTTPonlyとセキュアフラグを設定します。 2。すべてのユーザー入力のエクスポートコード。 3.コンテンツセキュリティポリシー(CSP)を実装して、スクリプトソースを制限します。これらのポリシーを通じて、セッション関連のXSS攻撃を効果的に保護し、ユーザーデータを確保できます。

PHPセッションのパフォーマンスを最適化するにはどうすればよいですか?PHPセッションのパフォーマンスを最適化するにはどうすればよいですか?Apr 23, 2025 am 12:13 AM

PHPセッションのパフォーマンスを最適化する方法は次のとおりです。1。遅延セッション開始、2。データベースを使用してセッションを保存します。これらの戦略は、高い並行性環境でのアプリケーションの効率を大幅に改善できます。

session.gc_maxlifetime構成設定とは何ですか?session.gc_maxlifetime構成設定とは何ですか?Apr 23, 2025 am 12:10 AM

thesession.gc_maxlifettinginttinginphpdethinesthelifsessessiondata、setinseconds.1)it'sconfiguredinphp.iniorviaini_set()。 2)AbalanceSneededToAvoidPerformanceIssues andunexpectedLogouts.3)php'sgarbagecollectionisisprobabilistic、影響を受けたBygc_probabi

PHPでセッション名をどのように構成しますか?PHPでセッション名をどのように構成しますか?Apr 23, 2025 am 12:08 AM

PHPでは、session_name()関数を使用してセッション名を構成できます。特定の手順は次のとおりです。1。session_name()関数を使用して、session_name( "my_session")などのセッション名を設定します。 2。セッション名を設定した後、session_start()を呼び出してセッションを開始します。セッション名の構成は、複数のアプリケーション間のセッションデータの競合を回避し、セキュリティを強化することができますが、セッション名の一意性、セキュリティ、長さ、設定タイミングに注意してください。

セッションIDをどのくらいの頻度で再生する必要がありますか?セッションIDをどのくらいの頻度で再生する必要がありますか?Apr 23, 2025 am 12:03 AM

セッションIDは、機密操作の前、30分ごとにログイン時に定期的に再生する必要があります。 1.セッション固定攻撃を防ぐためにログインするときにセッションIDを再生します。 2。安全性を向上させるために、敏感な操作の前に再生します。 3.定期的な再生は長期的な利用リスクを減らしますが、ユーザーエクスペリエンスの重量を量る必要があります。

PHPでセッションCookieパラメーターをどのように設定しますか?PHPでセッションCookieパラメーターをどのように設定しますか?Apr 22, 2025 pm 05:33 PM

PHPのセッションCookieパラメーターの設定は、session_set_cookie_params()関数を通じて達成できます。 1)この関数を使用して、有効期限、パス、ドメイン名、セキュリティフラグなどのパラメーターを設定します。 2)session_start()を呼び出して、パラメーターを有効にします。 3)ユーザーログインステータスなど、ニーズに応じてパラメーターを動的に調整します。 4)セキュリティを改善するために、セキュアとhttponlyフラグを設定することに注意してください。

PHPでセッションを使用する主な目的は何ですか?PHPでセッションを使用する主な目的は何ですか?Apr 22, 2025 pm 05:25 PM

PHPでセッションを使用する主な目的は、異なるページ間でユーザーのステータスを維持することです。 1)セッションはsession_start()関数を介して開始され、一意のセッションIDを作成し、ユーザーCookieに保存します。 2)セッションデータはサーバーに保存され、ログインステータスやショッピングカートのコンテンツなど、さまざまなリクエスト間でデータを渡すことができます。

サブドメイン間でセッションをどのように共有できますか?サブドメイン間でセッションをどのように共有できますか?Apr 22, 2025 pm 05:21 PM

サブドメイン間でセッションを共有する方法は?一般的なドメイン名にセッションCookieを設定することにより実装されます。 1.セッションCookieのドメインをサーバー側の.example.comに設定します。 2。メモリ、データベース、分散キャッシュなど、適切なセッションストレージ方法を選択します。 3. Cookieを介してセッションIDを渡すと、サーバーはIDに基づいてセッションデータを取得および更新します。

See all articles

ホット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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

SublimeText3 Mac版

SublimeText3 Mac版

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