Inhaltsverzeichnis
简介
前提条件
将CSV文件显示为一个表
Einführung
Voraussetzungen
CSV-Datei als Tabelle anzeigen
将原始CSV文件转换为数组
使用fgetcsv() ,将CSV文件转换成数组
使用array_map() 读取一个CSV文件
总结
Heim Backend-Entwicklung PHP-Tutorial 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

Feb 25, 2022 pm 04:20 PM
php 数组 CSV lesen

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
Nach dem Login kopieren

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

因此,在这篇文章中,我将教你如何使用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);
}

?>
Nach dem Login kopieren

在这个文件中,我们首先打开data.csv文件,它应该包含一些逗号分隔的数据。fopen 将在与csvtable.php相同的文件夹中寻找这个文件。&#39;r&#39; 参数告诉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;
Nach dem Login kopieren
Nach dem Login kopieren
'; ?>

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()</code verwenden > Methode Lesen Sie den Inhalt dieser Datei und konvertieren Sie diese CSV-Datei schließlich mit der Funktion <code>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;
Nach dem Login kopieren
Nach dem Login kopieren
'; ?>🎜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;
Nach dem Login kopieren
Nach dem Login kopieren
'; ?>

在上面的代码中,我们创建了一个函数来读取一个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;
Nach dem Login kopieren
Nach dem Login kopieren
'; ?>

上面的代码使用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!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

CakePHP-Projektkonfiguration CakePHP-Projektkonfiguration Sep 10, 2024 pm 05:25 PM

In diesem Kapitel werden wir die Umgebungsvariablen, die allgemeine Konfiguration, die Datenbankkonfiguration und die E-Mail-Konfiguration in CakePHP verstehen.

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

CakePHP Datum und Uhrzeit CakePHP Datum und Uhrzeit Sep 10, 2024 pm 05:27 PM

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

CakePHP-Datei hochladen CakePHP-Datei hochladen Sep 10, 2024 pm 05:27 PM

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

CakePHP-Routing CakePHP-Routing Sep 10, 2024 pm 05:25 PM

In diesem Kapitel lernen wir die folgenden Themen im Zusammenhang mit dem Routing kennen.

Besprechen Sie CakePHP Besprechen Sie CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein Dec 20, 2024 am 11:31 AM

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

CakePHP erstellt Validatoren CakePHP erstellt Validatoren Sep 10, 2024 pm 05:26 PM

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.

See all articles