Comment utiliser PHP pour lire du CSV dans un tableau ? L'article suivant vous montrera comment utiliser PHP pour lire le contenu CSV et le convertir en tableau. J'espère qu'il vous sera utile.
Dans cet article, je vais vous montrer comment utiliser les fonctions intégrées de PHP pour lire et imprimer le contenu d'un fichier CSV et le convertir en tableau. Nous utiliserons fopen()
et fgetcsv()
pour lire le contenu du fichier CSV, puis utiliserons array_map()
et str_getcsv () La fonction
le convertit en tableau. 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内置的本地函数非常好用。
要继续学习这篇文章,你需要以下条件。
我们开始吧!
在文章的这一部分,我们将读取一个简单的CSV文件,其中包含几个由逗号分隔的词。开始时,我们将使用上面的简单文件,以后我们可以继续使用一个随机的大文件。当然,你可以使用Microsoft Excel或文本编辑器创建自己的文件,并以CSV为扩展名保存。
要读取该文件,我们首先要在其保存的文件夹或位置找到它。为了方便访问,你可能想把它保存在你的程序文件的同一个文件夹里。然后我们可以使用fopen()
函数来读取该文件。
之后,fgetcsv()
函数从打开文件的解析行中检查CSV字段。这个函数需要三个参数:从fopen()
返回的文件句柄,要读取的行的最大长度,以及特殊的分隔符--我们称之为 "分隔符"。这可以是一个逗号、一个分号或任何其他分隔符。
现在让我们来实际操作一下。
在可以用WAMP或XAMPP提供服务的地方创建一个名为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字段,一次一行。我们告诉fgetcsv
,每行最多读取100个字符,并使用逗号分隔符作为分隔符。然后,在文件中找到的字被循环浏览,并打印到一个HTML表格中。
最后一个函数是fclose()
,它关闭了打开的文件。这将释放打开的文件所使用的内存,并允许其他进程访问该文件。
通过WAMP或XAMPP localhost服务器打开csvtable**.php**,或从命令行运行php read.php
Voici un exemple d'un tel fichier.
<?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 '
Ces données représentent des informations sur trois personnes, avec des colonnes correspondant à leurs noms, âges et emplois. Bien qu’il s’agisse d’un format de données simple, il est délicat à lire et à consommer.
Donc, dans cet article, je vais vous apprendre comment ouvrir un fichier CSV en utilisant les fonctions natives de PHP (telles que fopen()
) et comment utiliser le fgetcsv()</code > méthode Lisez le contenu de ce fichier, et enfin utilisez la fonction <code>array_map()
pour convertir ce fichier CSV en tableau.
fopen()
pour lire le fichier. 🎜🎜Ensuite, la fonction fgetcsv()
vérifie le champ CSV à partir de la ligne analysée du fichier ouvert. Cette fonction prend trois paramètres : le descripteur de fichier renvoyé par fopen()
, la longueur maximale des lignes à lire et un délimiteur spécial - nous l'appelons le "délimiteur". Cela peut être une virgule, un point-virgule ou tout autre délimiteur. 🎜🎜Maintenant, mettons-le en pratique. 🎜🎜Créez un fichier nommé csvtable.php quelque part qui peut être servi avec WAMP ou XAMPP et copiez le code suivant. 🎜<?php $csv = array_map('str_getcsv', file('data.csv')); echo '<pre class="brush:php;toolbar:false">'; print_r($csv); echo '
fopen
recherchera ce fichier dans le même dossier que csvtable.php. Le paramètre 'r'
indique à fopen
d'ouvrir le fichier en lecture seule. 🎜🎜Si le fichier est ouvert avec succès, fopen
renverra un descripteur de fichier qui peut être utilisé pour les opérations de lecture à partir d'autres fichiers. Sinon, il renvoie FALSE
. Par conséquent, avant de continuer à lire le fichier, nous vérifions si le descripteur de fichier est FALSE
. 🎜🎜Ensuite, les fichiers fgetcsv()
récupèrent les champs CSV du fichier ouvert, une ligne à la fois. Nous disons à fgetcsv
de lire jusqu'à 100 caractères par ligne et d'utiliser des délimiteurs par virgules comme délimiteurs. Les mots trouvés dans le fichier sont ensuite parcourus en boucle et imprimés dans un tableau HTML. 🎜🎜La dernière fonction est fclose()
, qui ferme le fichier ouvert. Cela libérera la mémoire utilisée par le fichier ouvert et permettra à d'autres processus d'accéder au fichier. 🎜🎜Ouvrez csvtable**.php** via le serveur localhost WAMP ou XAMPP, ou exécutez php read.php
à partir de la ligne de commande, vous pouvez voir le résultat suivant. 🎜🎜🎜🎜🎜La première partie de ce que nous devons implémenter est terminée 🎜🎜Nous allons maintenant passer à la conversion des champs CSV bruts en tableau ! 🎜现在,有不止一种方法来产生数组。我们可以使用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文件操作系列大汇总(持续更新~)
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!