如何使用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的開發環境--XAMPP或WampServer都很好用
- 對PHP概念的一些基本了解
我們開始吧!
將CSV檔案顯示為一個表格
#在文章的這一部分,我們將讀取一個簡單的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
,可以看到以下輸出。
我們需要實作的第一部分已經完成了!
現在,我們將跳轉到將原始CSV欄位轉換為陣列。
将原始CSV文件转换为数组
现在,有不止一种方法来产生数组。我们可以使用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文件操作系列大汇总(持续更新~)
以上是PHP中如何讀取CSV內容並存入一個陣列中的詳細內容。更多資訊請關注PHP中文網其他相關文章!

PHP仍然流行的原因是其易用性、靈活性和強大的生態系統。 1)易用性和簡單語法使其成為初學者的首選。 2)與web開發緊密結合,處理HTTP請求和數據庫交互出色。 3)龐大的生態系統提供了豐富的工具和庫。 4)活躍的社區和開源性質使其適應新需求和技術趨勢。

PHP和Python都是高層次的編程語言,廣泛應用於Web開發、數據處理和自動化任務。 1.PHP常用於構建動態網站和內容管理系統,而Python常用於構建Web框架和數據科學。 2.PHP使用echo輸出內容,Python使用print。 3.兩者都支持面向對象編程,但語法和關鍵字不同。 4.PHP支持弱類型轉換,Python則更嚴格。 5.PHP性能優化包括使用OPcache和異步編程,Python則使用cProfile和異步編程。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。

PHP在現代化進程中仍然重要,因為它支持大量網站和應用,並通過框架適應開發需求。 1.PHP7提升了性能並引入了新功能。 2.現代框架如Laravel、Symfony和CodeIgniter簡化開發,提高代碼質量。 3.性能優化和最佳實踐進一步提升應用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP類型提示提升代碼質量和可讀性。 1)標量類型提示:自PHP7.0起,允許在函數參數中指定基本數據類型,如int、float等。 2)返回類型提示:確保函數返回值類型的一致性。 3)聯合類型提示:自PHP8.0起,允許在函數參數或返回值中指定多個類型。 4)可空類型提示:允許包含null值,處理可能返回空值的函數。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版
視覺化網頁開發工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。