PHP를 사용하여 CSV를 배열로 읽는 방법은 무엇입니까? 다음 기사에서는 PHP를 사용하여 CSV 콘텐츠를 읽고 이를 배열로 변환하는 방법을 보여줍니다. 도움이 되기를 바랍니다.
이 기사에서는 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的开发环境--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 파일은 읽고 쓰기 쉽고 기본 텍스트 편집기에서 열 수 있습니다. 이 유형의 파일은 표 형식의 데이터를 일반 텍스트로 저장합니다.이러한 파일의 예는 다음과 같습니다.
<?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 ''; ?>
이 데이터는 세 사람의 이름, 나이, 직업에 해당하는 열로 구성된 정보를 나타냅니다. 이는 단순한 데이터 형식이지만 읽고 사용하기가 까다롭습니다.
그래서 이번 글에서는 PHP의 기본 기능(예: fopen()
)을 사용하여 CSV 파일을 여는 방법과 fgetcsv()
를 사용하는 방법을 알려 드리겠습니다. > 메소드 이 파일의 내용을 읽고 마지막으로 array_map()
함수를 사용하여 이 CSV 파일을 배열로 변환합니다.
전제조건
🎜이 글을 계속 공부하려면 다음 조건이 필요합니다. 🎜- 컴퓨터에 PHP 5.6 이상 설치
- PHP 개발 환경--XAMPP🎜 또는 WampServer🎜는 모두 매우 유용합니다
- PHP 개념에 대한 기본적인 이해
CSV 파일을 테이블로 표시
🎜기사의 이 부분에서는 쉼표로 구분된 여러 단어가 포함된 간단한 CSV 파일을 읽습니다. 시작하려면 위의 간단한 파일을 사용하고 나중에 임의의 대용량 파일을 계속 사용할 수 있습니다. 물론 Microsoft Excel이나 텍스트 편집기를 사용하여 자신만의 파일을 만들고 CSV 확장자로 저장할 수 있습니다. 🎜🎜파일을 읽으려면 먼저 파일이 저장된 폴더나 위치에서 파일을 찾아야 합니다. 더 쉽게 액세스하려면 프로그램 파일과 동일한 폴더에 저장하는 것이 좋습니다. 그런 다음fopen()
함수를 사용하여 파일을 읽을 수 있습니다. 🎜🎜이후 fgetcsv()
함수는 열린 파일의 구문 분석된 줄에서 CSV 필드를 확인합니다. 이 함수는 fopen()
에서 반환된 파일 핸들, 읽을 줄의 최대 길이, 특수 구분 기호 등 세 가지 매개 변수를 사용합니다. 이를 "구분 기호"라고 합니다. 쉼표, 세미콜론 또는 기타 구분 기호가 될 수 있습니다. 🎜🎜이제 실제로 해봅시다. 🎜🎜WAMP 또는 XAMPP와 함께 제공될 수 있는 위치에 csvtable.php라는 파일을 만들고 다음 코드를 복사하세요. 🎜<?php $csv = array_map('str_getcsv', file('data.csv')); echo '<pre class="brush:php;toolbar:false">'; print_r($csv); echo ''; ?>🎜이 파일에서는 먼저 쉼표로 구분된 데이터가 포함되어 있는 data.csv 파일을 엽니다.
fopen
은 csvtable.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, '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文件操作系列大汇总(持续更新~)
위 내용은 CSV 콘텐츠를 읽고 PHP에서 배열에 저장하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

PHP는 동적 웹 사이트를 구축하는 데 사용되며 해당 핵심 기능에는 다음이 포함됩니다. 1. 데이터베이스와 연결하여 동적 컨텐츠를 생성하고 웹 페이지를 실시간으로 생성합니다. 2. 사용자 상호 작용 및 양식 제출을 처리하고 입력을 확인하고 작업에 응답합니다. 3. 개인화 된 경험을 제공하기 위해 세션 및 사용자 인증을 관리합니다. 4. 성능을 최적화하고 모범 사례를 따라 웹 사이트 효율성 및 보안을 개선하십시오.

PHP는 MySQLI 및 PDO 확장 기능을 사용하여 데이터베이스 작업 및 서버 측 로직 프로세싱에서 상호 작용하고 세션 관리와 같은 기능을 통해 서버 측로 로직을 처리합니다. 1) MySQLI 또는 PDO를 사용하여 데이터베이스에 연결하고 SQL 쿼리를 실행하십시오. 2) 세션 관리 및 기타 기능을 통해 HTTP 요청 및 사용자 상태를 처리합니다. 3) 트랜잭션을 사용하여 데이터베이스 작업의 원자력을 보장하십시오. 4) SQL 주입 방지, 디버깅을 위해 예외 처리 및 폐쇄 연결을 사용하십시오. 5) 인덱싱 및 캐시를 통해 성능을 최적화하고, 읽을 수있는 코드를 작성하고, 오류 처리를 수행하십시오.

PHP에서 전처리 문과 PDO를 사용하면 SQL 주입 공격을 효과적으로 방지 할 수 있습니다. 1) PDO를 사용하여 데이터베이스에 연결하고 오류 모드를 설정하십시오. 2) 준비 방법을 통해 전처리 명세서를 작성하고 자리 표시자를 사용하여 데이터를 전달하고 방법을 실행하십시오. 3) 쿼리 결과를 처리하고 코드의 보안 및 성능을 보장합니다.

PHP와 Python은 고유 한 장점과 단점이 있으며 선택은 프로젝트 요구와 개인 선호도에 달려 있습니다. 1.PHP는 대규모 웹 애플리케이션의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 데이터 과학 및 기계 학습 분야를 지배합니다.

PHP는 전자 상거래, 컨텐츠 관리 시스템 및 API 개발에 널리 사용됩니다. 1) 전자 상거래 : 쇼핑 카트 기능 및 지불 처리에 사용됩니다. 2) 컨텐츠 관리 시스템 : 동적 컨텐츠 생성 및 사용자 관리에 사용됩니다. 3) API 개발 : 편안한 API 개발 및 API 보안에 사용됩니다. 성능 최적화 및 모범 사례를 통해 PHP 애플리케이션의 효율성과 유지 보수 성이 향상됩니다.

PHP를 사용하면 대화식 웹 컨텐츠를 쉽게 만들 수 있습니다. 1) HTML을 포함하여 컨텐츠를 동적으로 생성하고 사용자 입력 또는 데이터베이스 데이터를 기반으로 실시간으로 표시합니다. 2) 프로세스 양식 제출 및 동적 출력을 생성하여 htmlspecialchars를 사용하여 XSS를 방지합니다. 3) MySQL을 사용하여 사용자 등록 시스템을 작성하고 Password_Hash 및 전처리 명세서를 사용하여 보안을 향상시킵니다. 이러한 기술을 마스터하면 웹 개발의 효율성이 향상됩니다.

PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

PHP는 여전히 역동적이며 현대 프로그래밍 분야에서 여전히 중요한 위치를 차지하고 있습니다. 1) PHP의 단순성과 강력한 커뮤니티 지원으로 인해 웹 개발에 널리 사용됩니다. 2) 유연성과 안정성은 웹 양식, 데이터베이스 작업 및 파일 처리를 처리하는 데 탁월합니다. 3) PHP는 지속적으로 발전하고 최적화하며 초보자 및 숙련 된 개발자에게 적합합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Dreamweaver Mac版
시각적 웹 개발 도구

안전한 시험 브라우저
안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
