>백엔드 개발 >PHP 튜토리얼 >PHP 배열을 헤더가 있는 올바른 형식의 CSV 파일로 변환하는 방법은 무엇입니까?

PHP 배열을 헤더가 있는 올바른 형식의 CSV 파일로 변환하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-19 18:58:30379검색

How to Convert a PHP Array to a Well-Formatted CSV File with Headers?

PHP 배열을 CSV로 변환: 간소화된 솔루션

PHP에서 배열을 CSV 파일로 변환하는 것은 어려울 수 있습니다. 올바른 형식의 CSV를 생성하는 데 어려움을 겪고 있다면 이 기사가 더 나은 솔루션을 제공할 것입니다.

문제: 단일 행 CSV 및 헤더 없음

다음 코드를 고려하십시오.

<code class="php">$prods = [1, 2, 3];

foreach ($prods as $prod) {
    $sql = "SELECT * FROM products WHERE id = '$prod'";
    $result = $mysqli->query($sql);
    $info = $result->fetch_array(); 
}

// ... rest of the code</code>

이 코드로 인해 헤더와 줄바꿈이 있는 원하는 형식 대신 긴 한 줄의 CSV 파일이 생성될 수 있습니다.

해결책: fputcsv() 사용

이 문제를 해결하려면 CSV 파일에 쓰는 코드를 다음으로 바꾸세요.

<code class="php">$output = fopen("php://output",'w') or die("Can't open php://output");
header("Content-Type:application/csv"); 
header("Content-Disposition:attachment;filename=pressurecsv.csv"); 
fputcsv($output, array('id','name','description'));
foreach($prod as $product) {
    fputcsv($output, $product);
}
fclose($output) or die("Can't close php://output");</code>

fputcsv() 함수는 이스케이프, 필드 구분 기호 및 줄 끝을 자동으로 처리하여 CSV 형식이 올바른지 확인합니다. .

추가 참고 사항

  • 파일 이름을 하드 코딩하는 대신 fopen('php://output', 'w')을 사용하여 메모리에 CSV를 생성하세요.
  • header()에 CSV 다운로드에 적합한 헤더를 설정합니다.
  • fputcsv()를 사용하여 CSV의 헤더 행과 후속 행을 작성합니다.
  • 파일을 마지막으로 닫습니다. fclose()를 사용합니다.

위 내용은 PHP 배열을 헤더가 있는 올바른 형식의 CSV 파일로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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