Background
PHP로 Excel로 내보내기의 최적화는 이전 글에서 소개했습니다: PHP 메모리 오버플로에 대해 생각하면서, 이번 글은 주로 고성능 내보내기 컴포넌트 – PHP C 확장인 xlswriter 공식 문서 주소는 을 클릭하세요.
권장: PHP 비디오 튜토리얼
설치
pecl 설치
pecl이 설치되지 않은 것을 발견하면 pecl을 설치해야 합니다. 일반적으로 PHP 설치 디렉터리에 설치됩니다.
# 进入PHP安装目录 cd /usr/local/php/bin curl -o go-pear.php http://pear.php.net/go-pear.phar php go-pear.php # 安装完成后,软连接到bin目录下 ln -s /usr/local/php/bin/pecl /usr/bin/pecl
Install xlswriter
pecl install xlswriter # 添加 extension = xlswriter.so 到 ini 配置
사용# 🎜🎜#
구체적인 사용법은 공식 문서를 참조하세요. 더 자세히 소개될 코드는 다음과 같습니다. 캡슐화된 내보내기 서비스#🎜🎜 #/** * 下载 * @param $header * @param $data * @param $fileName * @param $type * @return bool * @throws */ public function download($header, $data, $fileName) { $config = [ 'path' => $this->getTmpDir() . '/', ]; $now = date('YmdHis'); $fileName = $fileName . $now . '.xlsx'; $xlsxObject = new \Vtiful\Kernel\Excel($config); // Init File $fileObject = $xlsxObject->fileName($fileName); // 设置样式 $fileHandle = $fileObject->getHandle(); $format = new \Vtiful\Kernel\Format($fileHandle); $style = $format->bold()->background( \Vtiful\Kernel\Format::COLOR_YELLOW )->align(Format::FORMAT_ALIGN_VERTICAL_CENTER)->toResource(); // Writing data to a file ...... $fileObject->header($header) ->data($data) ->freezePanes(1, 0) ->setRow('A1', 20, $style); // Outptu $filePath = $fileObject->output(); // 下载 header("Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"); header('Content-Disposition: attachment;filename="' . $fileName . '"'); header('Cache-Control: max-age=0'); header('Content-Length: ' . filesize($filePath)); header('Content-Transfer-Encoding: binary'); header('Cache-Control: must-revalidate'); header('Pragma: public'); ob_clean(); flush(); if (copy($filePath, 'php://output') === false) { throw new RuntimeException('导出失败'); } // Delete temporary file @unlink($filePath); return true; } /** * 获取临时文件夹 * @return false|string */ private function getTmpDir() { // 目录可以自定义 // return \Yii::$app->params['downloadPath']; $tmp = ini_get('upload_tmp_dir'); if ($tmp !== False && file_exists($tmp)) { return realpath($tmp); } return realpath(sys_get_temp_dir()); } /** * 读取文件 * @param $path * @param $fileName * @return array */ public function readFile($path,$fileName) { // 读取测试文件 $config = ['path' => $path]; $excel = new \Vtiful\Kernel\Excel($config); $data = $excel->openFile($fileName) ->openSheet() ->getSheetData(); return $data; }
통화 코드
Export
/** * 导出 */ public function actionExport() { try { /** * @var $searchModel SkuBarCodeSearch */ $searchModel = Yii::createObject(SkuBarCodeSearch::className()); $queryParams['SkuBarCodeSearch'] = []; $result = $searchModel->search($queryParams, true); $formatData = []; if (!empty($result)) { foreach ($result as $key => &$value) { $tmpData = [ 'sku_code' => $value['sku_code'], 'bar_code' => $value['bar_code'], 'created_at' => $value['created_at'], 'updated_at' => $value['updated_at'], ]; $formatData[] = array_values($tmpData); } unset($value); } $fields = [ 'sku_code' => 'SKU编码', 'bar_code' => '条形码', 'created_at' => '创建时间', 'updated_at' => '更新时间', ]; /** * @var $utilService UtilService */ $utilService = UtilService::getInstance(); $utilService->download(array_values($fields), $formatData, 'sku_single_code'); } catch (\Exception $e) { Yii::$app->getSession()->setFlash('error', '导出失败'); } }
Import
public function actionImportTmpSku() { try { /** * @var $utilService UtilService */ $utilService = UtilService::getInstance(); $path = '/tmp/'; // 文件目录 $fileName = 'sku_0320.xlsx'; $excelData = $utilService->readFile($path, $fileName); unset($excelData[0]); $excelData = array_merge($excelData); // ... ... 业务代码 } catch (\Exception $e) { echo $e->getMessage(); exit; } }결론
# 🎜🎜# 전체적으로 사용해본 결과 대용량 데이터를 처리할 때 성능은 확실히 기존 PHPExcel보다 훨씬 뛰어납니다.
이 기사는 재인쇄되었으며 원본 주소는 다음과 같습니다.
https://tsmliyun.github.io/php/PHP%E5%AF%BC% E5% 87%BAExcel%E7%9A%84%E4%BC%98%E5%8C%96/
위 내용은 Excel로 PHP 내보내기 최적화에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

PHP는 주로 절차 적 프로그래밍이지만 객체 지향 프로그래밍 (OOP)도 지원합니다. Python은 OOP, 기능 및 절차 프로그래밍을 포함한 다양한 패러다임을 지원합니다. PHP는 웹 개발에 적합하며 Python은 데이터 분석 및 기계 학습과 같은 다양한 응용 프로그램에 적합합니다.

PHP는 1994 년에 시작되었으며 Rasmuslerdorf에 의해 개발되었습니다. 원래 웹 사이트 방문자를 추적하는 데 사용되었으며 점차 서버 측 스크립팅 언어로 진화했으며 웹 개발에 널리 사용되었습니다. Python은 1980 년대 후반 Guidovan Rossum에 의해 개발되었으며 1991 년에 처음 출시되었습니다. 코드 가독성과 단순성을 강조하며 과학 컴퓨팅, 데이터 분석 및 기타 분야에 적합합니다.

PHP는 웹 개발 및 빠른 프로토 타이핑에 적합하며 Python은 데이터 과학 및 기계 학습에 적합합니다. 1.PHP는 간단한 구문과 함께 동적 웹 개발에 사용되며 빠른 개발에 적합합니다. 2. Python은 간결한 구문을 가지고 있으며 여러 분야에 적합하며 강력한 라이브러리 생태계가 있습니다.

PHP는 현대화 프로세스에서 많은 웹 사이트 및 응용 프로그램을 지원하고 프레임 워크를 통해 개발 요구에 적응하기 때문에 여전히 중요합니다. 1.PHP7은 성능을 향상시키고 새로운 기능을 소개합니다. 2. Laravel, Symfony 및 Codeigniter와 같은 현대 프레임 워크는 개발을 단순화하고 코드 품질을 향상시킵니다. 3. 성능 최적화 및 모범 사례는 응용 프로그램 효율성을 더욱 향상시킵니다.

phphassignificallyimpactedwebdevelopmentandextendsbeyondit

PHP 유형은 코드 품질과 가독성을 향상시키기위한 프롬프트입니다. 1) 스칼라 유형 팁 : PHP7.0이므로 int, float 등과 같은 기능 매개 변수에 기본 데이터 유형을 지정할 수 있습니다. 2) 반환 유형 프롬프트 : 기능 반환 값 유형의 일관성을 확인하십시오. 3) Union 유형 프롬프트 : PHP8.0이므로 기능 매개 변수 또는 반환 값에 여러 유형을 지정할 수 있습니다. 4) Nullable 유형 프롬프트 : NULL 값을 포함하고 널 값을 반환 할 수있는 기능을 포함 할 수 있습니다.

PHP에서는 클론 키워드를 사용하여 객체 사본을 만들고 \ _ \ _ Clone Magic 메소드를 통해 클로닝 동작을 사용자 정의하십시오. 1. 복제 키워드를 사용하여 얕은 사본을 만들어 객체의 속성을 복제하지만 객체의 속성은 아닙니다. 2. \ _ \ _ 클론 방법은 얕은 복사 문제를 피하기 위해 중첩 된 물체를 깊이 복사 할 수 있습니다. 3. 복제의 순환 참조 및 성능 문제를 피하고 클로닝 작업을 최적화하여 효율성을 향상시키기 위해주의를 기울이십시오.

PHP는 웹 개발 및 컨텐츠 관리 시스템에 적합하며 Python은 데이터 과학, 기계 학습 및 자동화 스크립트에 적합합니다. 1.PHP는 빠르고 확장 가능한 웹 사이트 및 응용 프로그램을 구축하는 데 잘 작동하며 WordPress와 같은 CMS에서 일반적으로 사용됩니다. 2. Python은 Numpy 및 Tensorflow와 같은 풍부한 라이브러리를 통해 데이터 과학 및 기계 학습 분야에서 뛰어난 공연을했습니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

드림위버 CS6
시각적 웹 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
