>백엔드 개발 >PHP 튜토리얼 >PHP를 사용하여 CSV 파일을 만드는 방법은 무엇입니까? (코드 예)

PHP를 사용하여 CSV 파일을 만드는 방법은 무엇입니까? (코드 예)

青灯夜游
青灯夜游원래의
2019-02-16 16:32:063772검색

CSV(쉼표로 구분된 값)는 응용 프로그램 간에 표 형식의 데이터를 전송하는 가장 일반적인 방법 중 하나입니다. 데이터를 CSV로 내보내는 코드를 만드는 것은 많은 응용 프로그램에서 매우 유용할 수 있습니다. 다음 기사는 PHP를 사용하여 CSV 파일을 만드는 방법을 보여줍니다. 도움이 되기를 바랍니다.

PHP를 사용하여 CSV 파일을 만드는 방법은 무엇입니까? (코드 예)

코드 예제를 통해 자세히 소개하겠습니다.

정적 데이터를 사용하여 CSV 파일 만들기

데이터를 csv 파일에 저장하려면 다음과 유사한 코드를 사용하면 됩니다. :

<?php
// 创建并打开“demosaved.csv”文件进行写入
$file = fopen(&#39;demosaved.csv&#39;, &#39;w&#39;);
 
// 保存列标题
fputcsv($file, array(&#39;Column 1&#39;, &#39;Column 2&#39;, &#39;Column 3&#39;, &#39;Column 4&#39;, &#39;Column 5&#39;));
 
// 样本数据,这可以从MySQL中获取
$data = array(
array(&#39;Data 11&#39;, &#39;Data 12&#39;, &#39;Data 13&#39;, &#39;Data 14&#39;, &#39;Data 15&#39;),
array(&#39;Data 21&#39;, &#39;Data 22&#39;, &#39;Data 23&#39;, &#39;Data 24&#39;, &#39;Data 25&#39;),
array(&#39;Data 31&#39;, &#39;Data 32&#39;, &#39;Data 33&#39;, &#39;Data 34&#39;, &#39;Data 35&#39;),
array(&#39;Data 41&#39;, &#39;Data 42&#39;, &#39;Data 43&#39;, &#39;Data 44&#39;, &#39;Data 45&#39;),
array(&#39;Data 51&#39;, &#39;Data 52&#39;, &#39;Data 53&#39;, &#39;Data 54&#39;, &#39;Data 55&#39;)
);
 
// 保存每一行数据
foreach ($data as $row)
{
fputcsv($file, $row);
}
 
// 关闭文件
fclose($file);
?>

코드 설명

3행: 쓰기용 "demosaved.csv" 파일을 엽니다. 서버가 이 파일이 저장된 위치에 쓸 수 있는지 확인하세요.

라인 6: 열 헤더를 추가합니다. 열 헤더를 원하지 않으면 이 단계를 건너뛸 수 있습니다.

Line 9-15: 파일에 저장될 데이터를 나타냅니다. mysql에서 데이터를 가져오려면 코드를 사용하여 데이터베이스에 연결하고 데이터를 가져온 다음 이 줄을

17-21줄: 데이터의 각 행을 반복하고 데이터를 저장합니다

24줄로 바꿔야 합니다. : 파일을 닫습니다. 파일에 모든 데이터 쓰기를 마친 후에는 파일을 닫아야 합니다.

mysql에서 데이터를 가져와서 CSV 파일 생성 및 자동 다운로드

<?php
// 设置输出标头,以便下载文件
header(&#39;Content-type: text/csv&#39;);
header(&#39;Content-Disposition: attachment; filename="demo.csv"&#39;);
 
// 不缓存文件
header(&#39;Pragma: no-cache&#39;);
header(&#39;Expires: 0&#39;);
 
// 创建连接到输出流的文件指针
$file = fopen(&#39;php://output&#39;, &#39;w&#39;);
 
// 打开数据库连接
$link = mysqli_connect(&#39;localhost&#39;, &#39;my_user&#39;, &#39;my_password&#39;, &#39;my_db&#39;);
 
//查询数据库
$query = &#39;SELECT field1, field2, field3, field4, field5 FROM table&#39;;
 
if ($rows = mysqli_query($link, $query))
{
// 保存每一行数据
while ($row = mysqli_fetch_assoc($rows))
{
fputcsv($file, $row);
}
//自由结果集
mysqli_free_result($result);
}
// 关闭连接
mysqli_close($link);
?>

코드 설명:

파일을 다운로드하고 싶기 때문에 일부 헤더(3행과 4행)를 보내야 합니다. 브라우저에서 파일을 다운로드합니다.

3행: csv 파일을 전송하므로 콘텐츠의 MIME 유형이 text/csv라고 브라우저에 알립니다.

4행: "attachment" 값과 파일 이름이 포함된 "Content-Disposition" 헤더를 보냅니다. "데모.csv". 이렇게 하면 브라우저가 "demo.csv"라는 파일을 표시하는 대신 다운로드하도록 지시합니다.

라인 7 및 8: 파일을 캐시하지 않도록 브라우저에 지시합니다. 이는 동일한 이름을 가진 여러 파일을 보낼 때 유용하며, 그렇지 않으면 필요하지 않습니다.

11행: 데이터를 보내기 위해 파일 포인터를 여는 것을 나타냅니다.

14행 ~ 30행: mysql에서 데이터 가져오기

참고: 필요 데이터베이스의 연결 매개변수와 쿼리를 변경했는지 확인하세요. 또한, 이 데이터베이스 관련 코드는 단지 예시일 뿐입니다. 실제 애플리케이션에서는 다른 파일에 있을 수 있으며 오류 처리도 있어야 합니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 공부에 도움이 되었으면 좋겠습니다. 더 흥미로운 내용을 보려면 PHP 중국어 웹사이트의 관련 튜토리얼 열을 주의 깊게 살펴보세요! ! !

위 내용은 PHP를 사용하여 CSV 파일을 만드는 방법은 무엇입니까? (코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.