首頁  >  文章  >  後端開發  >  PHP中如何讀取CSV內容並存入一個陣列中

PHP中如何讀取CSV內容並存入一個陣列中

青灯夜游
青灯夜游轉載
2022-02-25 16:20:407681瀏覽

如何使用PHP把CSV讀成一個陣列?以下這篇文章帶大家了解使用PHP讀取CSV內容,並轉換成陣列的方法,希望對大家有幫助。

PHP中如何讀取CSV內容並存入一個陣列中

在這篇文章中,我將向你展示如何使用PHP的內建函數來讀取和列印一個CSV檔案的內容,並將其轉換成一個陣列。我們將使用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 ,可以看到以下輸出。

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中文網其他相關文章!

陳述:
本文轉載於:juejin.cn。如有侵權,請聯絡admin@php.cn刪除