>백엔드 개발 >PHP 문제 >PHP에서 Excel로 배열을 내보내는 방법

PHP에서 Excel로 배열을 내보내는 방법

王林
王林원래의
2023-05-05 20:34:051022검색

개발 과정에서 사용자가 쉽게 다운로드하고 저장할 수 있도록 데이터를 Excel 파일로 내보내야 하는 경우가 많습니다. 널리 사용되는 서버측 프로그래밍 언어인 Php도 이 기능을 쉽게 구현할 수 있습니다. 이 기사에서는 Php를 사용하여 배열을 Excel 파일로 내보내는 방법을 소개합니다.

1. 준비

코딩을 시작하기 전에 먼저 오픈소스 Php Excel 처리 라이브러리인 PHPExcel이 서버에 설치되어 있는지 확인해야 합니다. 아직 설치하지 않았다면 PHPExcel 공식 웹사이트에 가서 다운로드할 수 있습니다. PHPExcel 라이브러리 파일을 프로젝트 폴더에 복사하기만 하면 됩니다.

2. Excel 파일 만들기 및 데이터 쓰기

새 Excel 파일 만들기 및 데이터 쓰기는 PHPExcel 라이브러리의 PHPExcel 개체를 통해 수행되어야 합니다. 사용하기 쉬운 PHPExcel 개체는 Excel 파일의 다양한 속성을 정의할 수 있도록 몇 가지 유용한 기능을 제공합니다.

예를 들어, 새 Excel 파일을 만들고 데이터를 더 잘 표시하기 위해 열 너비와 행 높이를 정의하려는 경우 다음 코드를 사용할 수 있습니다.

//创建PHPExcel对象
$objPHPExcel = new PHPExcel();

//设置列宽
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(30);

//设置行高
$objPHPExcel->getActiveSheet()->getRowDimension(1)->setRowHeight(30);
$objPHPExcel->getActiveSheet()->getRowDimension(2)->setRowHeight(20);

Excel 파일의 속성을 설정한 후 다음을 수행할 수 있습니다. 이제 Excel 파일에 데이터를 씁니다. 배열 데이터를 Excel로 내보내는 방법을 보여주기 위해 아래와 같은 배열 데이터가 있다고 가정할 수 있습니다.

$data = array(
    array('姓名', '年龄', '性别'),
    array('张三', '18', '男'),
    array('李四', '20', '女'),
    array('王五', '22', '男'),
);

이 배열 데이터를 Excel 파일에 쓰려면 다음 코드를 사용할 수 있습니다.

//写入数据到工作表1
$objPHPExcel->setActiveSheetIndex(0);
$objPHPExcel->getActiveSheet()->fromArray($data, NULL, 'A1');

위 코드는 배열을 씁니다. data $data to Excel 파일의 시트 1에는 행 1과 열 1부터 데이터가 기록됩니다. $null은 PhpExcel이 입력된 데이터에 따라 셀 형식을 자동으로 조정한다는 의미입니다.

3. Excel 파일 내보내기

배열 데이터를 Excel 파일에 쓴 후 마지막 단계는 생성된 Excel 파일을 로컬로 내보내는 것입니다. 이를 위해서는 몇 가지 응답 헤더를 설정해야 합니다.

먼저 사용자가 내용을 더 잘 식별할 수 있도록 수신된 Excel 파일의 파일 이름을 설정해야 합니다. 다음으로, 브라우저가 일반 텍스트 파일이 아닌 Excel 파일로 처리하도록 브라우저에 Excel 파일을 사용자에게 전달하도록 지시해야 합니다.

위 기능을 구현하는 코드는 다음과 같습니다.

//设置响应头信息
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="测试导出.xlsx"');
header('Cache-Control: max-age=0');

//创建Excel文件
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');

//导出Excel文件到本地
$objWriter->save('php://output');

위 코드는 관련 응답 헤더 정보를 설정하여 브라우저가 엑셀 파일을 받도록 지시합니다. 그런 다음 PHPExcel_IOFactory 객체를 생성하고 이를 사용하여 파일에 데이터를 쓰고 파일을 저장합니다.

마지막으로 $objWriter->save('php://output') 함수를 호출하여 Excel 파일을 클라이언트로 내보냅니다.

4. 완전한 코드

위의 코드 부분을 결합하면 배열 데이터를 Excel 파일로 내보내는 기능을 구현할 수 있습니다.

완전한 코드는 다음과 같습니다.

//引入PHPExcel库文件
require_once 'PHPExcel.php';

//创建PHPExcel对象
$objPHPExcel = new PHPExcel();

//设置列宽
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(20);
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(30);

//设置行高
$objPHPExcel->getActiveSheet()->getRowDimension(1)->setRowHeight(30);
$objPHPExcel->getActiveSheet()->getRowDimension(2)->setRowHeight(20);

//定义数据
$data = array(
    array('姓名', '年龄', '性别'),
    array('张三', '18', '男'),
    array('李四', '20', '女'),
    array('王五', '22', '男'),
);

//将数组写入Excel文件
$objPHPExcel->setActiveSheetIndex(0);
$objPHPExcel->getActiveSheet()->fromArray($data, NULL, 'A1');

//设置响应头信息
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="测试导出.xlsx"');
header('Cache-Control: max-age=0');

//创建Excel文件
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');

//导出Excel文件到本地
$objWriter->save('php://output');

위 코드는 PHPExcel 라이브러리를 사용하여 Excel 개체를 만들고, Excel에 데이터를 쓰고, 마지막으로 Excel 파일을 클라이언트로 내보냅니다.

5. 요약

Php는 널리 사용되는 서버측 프로그래밍 언어로, PHPExcel 라이브러리와 결합되어 배열 데이터를 Excel 파일로 쉽게 내보낼 수 있으며 사용자에게 다운로드 및 저장할 수 있습니다. 위의 예에서는 PHPExcel 라이브러리를 사용하여 Excel 통합 문서를 만들고, 데이터를 쓰고, 파일을 내보내는 방법을 소개했습니다. Php 개발 시 Excel 내보내기에 도움이 되기를 바랍니다.

위 내용은 PHP에서 Excel로 배열을 내보내는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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