Heim  >  Artikel  >  Backend-Entwicklung  >  So lesen Sie CSV-Inhalte und speichern sie in einem Array in PHP

So lesen Sie CSV-Inhalte und speichern sie in einem Array in PHP

青灯夜游
青灯夜游nach vorne
2022-02-25 16:20:407680Durchsuche

Wie verwende ich PHP, um CSV in ein Array einzulesen? Der folgende Artikel zeigt Ihnen, wie Sie mit PHP CSV-Inhalte lesen und in ein Array konvertieren. Ich hoffe, dass er für Sie hilfreich ist.

So lesen Sie CSV-Inhalte und speichern sie in einem Array in PHP

In diesem Artikel zeige ich Ihnen, wie Sie die integrierten PHP-Funktionen verwenden, um den Inhalt einer CSV-Datei zu lesen, zu drucken und in ein Array zu konvertieren. Wir verwenden fopen() und fgetcsv(), um den Inhalt der CSV-Datei zu lesen, und verwenden dann array_map() und str_getcsv () -Funktion wandelt es in ein Array um. fopen()fgetcsv() 读取CSV文件的内容,然后使用array_map()str_getcsv() 函数将其转换成数组。

简介

以逗号分隔的数值(CSV)格式存储数据文件并不是什么新鲜事。事实上,由于其简单性,它是最常见的数据存储方式之一--CSV文件易于读写,并且可以在基本的文本编辑器中打开。这种类型的文件以纯文本的形式存储表格数据。

这样一个文件的例子是这样的。

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

这个数据代表了三个人的信息,有对应于他们名字、年龄和工作的列。虽然这是一种简单的数据格式,但它的阅读和消费是很棘手的。

因此,在这篇文章中,我将教你如何使用PHP的原生函数(如fopen() )打开CSV文件,如何使用fgetcsv() 方法读取这个文件的内容,最后是如何使用array_map() 函数将这个CSV文件转换成一个数组。

当然,我们可以使用一些第三方软件包来实现这些,但PHP内置的本地函数非常好用。

前提条件

要继续学习这篇文章,你需要以下条件。

  • 在你的机器上安装了 PHP 5.6 或更高的版本
  • 一个PHP的开发环境--XAMPPWampServer都很好用
  • 对PHP概念的一些基本了解

我们开始吧!

将CSV文件显示为一个表

在文章的这一部分,我们将读取一个简单的CSV文件,其中包含几个由逗号分隔的词。开始时,我们将使用上面的简单文件,以后我们可以继续使用一个随机的大文件。当然,你可以使用Microsoft Excel或文本编辑器创建自己的文件,并以CSV为扩展名保存。

要读取该文件,我们首先要在其保存的文件夹或位置找到它。为了方便访问,你可能想把它保存在你的程序文件的同一个文件夹里。然后我们可以使用fopen() 函数来读取该文件。

之后,fgetcsv() 函数从打开文件的解析行中检查CSV字段。这个函数需要三个参数:从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字段,一次一行。我们告诉fgetcsv ,每行最多读取100个字符,并使用逗号分隔符作为分隔符。然后,在文件中找到的字被循环浏览,并打印到一个HTML表格中。

最后一个函数是fclose() ,它关闭了打开的文件。这将释放打开的文件所使用的内存,并允许其他进程访问该文件。

通过WAMP或XAMPP localhost服务器打开csvtable**.php**,或从命令行运行php read.php

Einführung

Das Speichern von Datendateien im CSV-Format (Comma-Separated Value) ist nichts Neues. Tatsächlich ist es aufgrund seiner Einfachheit eine der gebräuchlichsten Methoden zum Speichern von Daten – CSV-Dateien sind leicht zu lesen und zu schreiben und können in einem einfachen Texteditor geöffnet werden. Dieser Dateityp speichert tabellarische Daten im Klartext.

So lesen Sie CSV-Inhalte und speichern sie in einem Array in PHPEin Beispiel für eine solche Datei ist diese.

<?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;
'; ?>

Diese Daten stellen Informationen über drei Personen dar, wobei die Spalten ihren Namen, ihrem Alter und ihrem Beruf entsprechen. Obwohl es sich um ein einfaches Datenformat handelt, ist es schwierig zu lesen und zu nutzen.

In diesem Artikel werde ich Ihnen also beibringen, wie Sie eine CSV-Datei mit den nativen PHP-Funktionen (z. B. fopen()) öffnen und wie Sie den fgetcsv()verwenden > Methode Lesen Sie den Inhalt dieser Datei und konvertieren Sie diese CSV-Datei schließlich mit der Funktion array_map() in ein Array.

🎜 Natürlich können wir einige Softwarepakete von Drittanbietern verwenden, um dies zu erreichen, aber die integrierten nativen Funktionen von PHP sind sehr einfach zu verwenden. 🎜

Voraussetzungen

🎜Um diesen Artikel weiter studieren zu können, benötigen Sie die folgenden Bedingungen. 🎜🎜Lass uns anfangen!🎜

CSV-Datei als Tabelle anzeigen

🎜In diesem Teil des Artikels lesen wir eine einfache CSV-Datei, die mehrere durch Kommas getrennte Wörter enthält. Zu Beginn verwenden wir die obige einfache Datei und können später mit einer zufälligen großen Datei fortfahren. Natürlich können Sie Ihre eigene Datei mit Microsoft Excel oder einem Texteditor erstellen und diese mit einer CSV-Erweiterung speichern. 🎜🎜Um die Datei zu lesen, müssen wir sie zunächst in dem Ordner oder Ort finden, an dem sie gespeichert ist. Um den Zugriff zu erleichtern, können Sie es im selben Ordner wie Ihre Programmdateien speichern. Anschließend können wir die Funktion fopen() verwenden, um die Datei zu lesen. 🎜🎜Danach überprüft die Funktion fgetcsv() das CSV-Feld aus der analysierten Zeile der geöffneten Datei. Diese Funktion benötigt drei Parameter: das von fopen() zurückgegebene Dateihandle, die maximale Länge der zu lesenden Zeilen und ein spezielles Trennzeichen – wir nennen es das „Trennzeichen“. Dies kann ein Komma, ein Semikolon oder ein anderes Trennzeichen sein. 🎜🎜Jetzt machen wir es in der Praxis. 🎜🎜Erstellen Sie irgendwo eine Datei mit dem Namen csvtable.php, die mit WAMP oder XAMPP bereitgestellt werden kann, und kopieren Sie den folgenden Code. 🎜
<?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;
'; ?>🎜In dieser Datei öffnen wir zunächst die Datei data.csv, die einige durch Kommas getrennte Daten enthalten sollte. fopen sucht nach dieser Datei im selben Ordner wie csvtable.php. Der Parameter 'r' weist fopen an, die Datei schreibgeschützt zu öffnen. 🎜🎜Wenn die Datei erfolgreich geöffnet wurde, gibt fopen ein Dateihandle zurück, das für Lesevorgänge aus anderen Dateien verwendet werden kann. Andernfalls wird FALSE zurückgegeben. Bevor wir mit dem Lesen der Datei fortfahren, prüfen wir daher, ob das Dateihandle FALSE ist. 🎜🎜Dann rufen fgetcsv()-Dateien die CSV-Felder Zeile für Zeile aus der geöffneten Datei ab. Wir weisen fgetcsv an, bis zu 100 Zeichen pro Zeile zu lesen und Komma-Trennzeichen als Trennzeichen zu verwenden. Die in der Datei gefundenen Wörter werden dann durchgeschleift und in eine HTML-Tabelle gedruckt. 🎜🎜Die letzte Funktion ist fclose(), die die geöffnete Datei schließt. Dadurch wird der von der geöffneten Datei verwendete Speicher freigegeben und andere Prozesse können auf die Datei zugreifen. 🎜🎜Öffnen Sie csvtable**.php** über den WAMP- oder XAMPP-Localhost-Server oder führen Sie php read.php über die Befehlszeile aus. Sie können die folgende Ausgabe sehen. 🎜🎜🎜🎜🎜Der erste Teil dessen, was wir implementieren müssen, ist erledigt 🎜🎜Jetzt beginnen wir mit der Konvertierung der rohen CSV-Felder in ein Array. 🎜

将原始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文件的内容将显示如下。

So lesen Sie CSV-Inhalte und speichern sie in einem Array in PHP

使用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

Das obige ist der detaillierte Inhalt vonSo lesen Sie CSV-Inhalte und speichern sie in einem Array in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Dieser Artikel ist reproduziert unter:juejin.cn. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen