> 백엔드 개발 > PHP 튜토리얼 > CSV 콘텐츠를 읽고 PHP에서 배열에 저장하는 방법

CSV 콘텐츠를 읽고 PHP에서 배열에 저장하는 방법

青灯夜游
풀어 주다: 2023-04-10 22:06:01
앞으로
7844명이 탐색했습니다.

PHP를 사용하여 CSV를 배열로 읽는 방법은 무엇입니까? 다음 기사에서는 PHP를 사용하여 CSV 콘텐츠를 읽고 이를 배열로 변환하는 방법을 보여줍니다. 도움이 되기를 바랍니다.

CSV 콘텐츠를 읽고 PHP에서 배열에 저장하는 방법

이 기사에서는 PHP에 내장된 함수를 사용하여 CSV 파일의 내용을 읽고 인쇄하고 배열로 변환하는 방법을 보여 드리겠습니다. fopen()fgetcsv()를 사용하여 CSV 파일의 내용을 읽은 다음 array_map()를 사용합니다. str_getcsv() 함수는 이를 배열로 변환합니다. 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相同的文件夹中寻找这个文件。&#39;r&#39; 参数告诉fopen ,以只读方式打开该文件。

如果文件被成功打开,fopen 将返回一个文件句柄,可用于其他文件的读取操作。否则,它将返回FALSE 。因此,在继续读取文件之前,我们检查文件句柄是否为FALSE

然后,fgetcsv() 文件从打开的文件中获取CSV字段,一次一行。我们告诉fgetcsv ,每行最多读取100个字符,并使用逗号分隔符作为分隔符。然后,在文件中找到的字被循环浏览,并打印到一个HTML表格中。

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

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

소개

데이터 파일을 쉼표로 구분된 값(CSV) 형식으로 저장하는 것은 새로운 것이 아닙니다. 실제로 이는 단순성으로 인해 데이터를 저장하는 가장 일반적인 방법 중 하나입니다. CSV 파일은 읽고 쓰기 쉽고 기본 텍스트 편집기에서 열 수 있습니다. 이 유형의 파일은 표 형식의 데이터를 일반 텍스트로 저장합니다.

CSV 콘텐츠를 읽고 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;
로그인 후 복사
로그인 후 복사
'; ?>

이 데이터는 세 사람의 이름, 나이, 직업에 해당하는 열로 구성된 정보를 나타냅니다. 이는 단순한 데이터 형식이지만 읽고 사용하기가 까다롭습니다.

그래서 이번 글에서는 PHP의 기본 기능(예: fopen())을 사용하여 CSV 파일을 여는 방법과 fgetcsv()</code를 사용하는 방법을 알려 드리겠습니다. > 메소드 이 파일의 내용을 읽고 마지막으로 <code>array_map() 함수를 사용하여 이 CSV 파일을 배열로 변환합니다.

🎜 물론 일부 타사 소프트웨어 패키지를 사용하여 이를 달성할 수도 있지만 PHP에 내장된 기본 기능은 사용하기 매우 쉽습니다. 🎜

전제조건

🎜이 글을 계속 공부하려면 다음 조건이 필요합니다. 🎜🎜시작하겠습니다!🎜

CSV 파일을 테이블로 표시

🎜기사의 이 부분에서는 쉼표로 구분된 여러 단어가 포함된 간단한 CSV 파일을 읽습니다. 시작하려면 위의 간단한 파일을 사용하고 나중에 임의의 대용량 파일을 계속 사용할 수 있습니다. 물론 Microsoft Excel이나 텍스트 편집기를 사용하여 자신만의 파일을 만들고 CSV 확장자로 저장할 수 있습니다. 🎜🎜파일을 읽으려면 먼저 파일이 저장된 폴더나 위치에서 파일을 찾아야 합니다. 더 쉽게 액세스하려면 프로그램 파일과 동일한 폴더에 저장하는 것이 좋습니다. 그런 다음 fopen() 함수를 사용하여 파일을 읽을 수 있습니다. 🎜🎜이후 fgetcsv() 함수는 열린 파일의 구문 분석된 줄에서 CSV 필드를 확인합니다. 이 함수는 fopen()에서 반환된 파일 핸들, 읽을 줄의 최대 길이, 특수 구분 기호 등 세 가지 매개 변수를 사용합니다. 이를 "구분 기호"라고 합니다. 쉼표, 세미콜론 또는 기타 구분 기호가 될 수 있습니다. 🎜🎜이제 실제로 해봅시다. 🎜🎜WAMP 또는 XAMPP와 함께 제공될 수 있는 위치에 csvtable.php라는 파일을 만들고 다음 코드를 복사하세요. 🎜
<?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;
로그인 후 복사
로그인 후 복사
'; ?>🎜이 파일에서는 먼저 쉼표로 구분된 데이터가 포함되어 있는 data.csv 파일을 엽니다. fopencsvtable.php와 동일한 폴더에서 이 파일을 찾습니다. 'r' 매개변수는 fopen에 파일을 읽기 전용으로 열도록 지시합니다. 🎜🎜파일이 성공적으로 열리면 fopen은 다른 파일에서 작업을 읽는 데 사용할 수 있는 파일 핸들을 반환합니다. 그렇지 않으면 FALSE를 반환합니다. 따라서 파일을 계속 읽기 전에 파일 핸들이 FALSE인지 확인합니다. 🎜🎜그런 다음 fgetcsv() 파일은 열린 파일에서 한 번에 한 줄씩 CSV 필드를 가져옵니다. fgetcsv에 한 줄에 최대 100자를 읽고 쉼표 구분 기호를 구분 기호로 사용하도록 지시합니다. 파일에서 발견된 단어는 반복되어 HTML 테이블로 인쇄됩니다. 🎜🎜마지막 함수는 열린 파일을 닫는 fclose()입니다. 이렇게 하면 열린 파일에서 사용하는 메모리가 확보되고 다른 프로세스가 파일에 액세스할 수 있습니다. 🎜🎜WAMP 또는 XAMPP 로컬 호스트 서버를 통해 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, &#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文件的内容将显示如下。

CSV 콘텐츠를 읽고 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

위 내용은 CSV 콘텐츠를 읽고 PHP에서 배열에 저장하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:juejin.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿