php教程 php手册 PHP与EXCEL PHPExcel

PHP与EXCEL PHPExcel

Jun 21, 2016 am 08:47 AM
phpexcel

1、PHPExcel简介

PHPExcel 是用来操作Office Excel 文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格,如 Excel (BIFF) .xls, Excel 2007 (OfficeOpenXML) .xlsx, CSV, Libre/OpenOffice Calc .ods, Gnumeric, PDF, HTML等等。

2、EXCEL导出文件

include 'PHPExcel.php';
include 'PHPExcel/Writer/Excel2007.php';
//或者include 'PHPExcel/Writer/Excel5.php'; 用于输出.xls的
创建一个excel
$objPHPExcel = new PHPExcel();
保存excel—2007格式
$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);
//或者$objWriter = new PHPExcel_Writer_Excel5($objPHPExcel); 非2007格式
$objWriter->save("xxx.xlsx");
直接输出到浏览器
$objWriter = new PHPExcel_Writer_Excel5($objPHPExcel);
header("Pragma; public");
header("Expires; 0″);
header("Cache-Control;must-revalidate, post-check=0, pre-check=0″);
header("Content-Type;application/force-download");
header("Content-Type;application/vnd.ms-execl");
header("Content-Type;application/octet-stream");
header("Content-Type;application/download");;
header('Content-Disposition;attachment;filename="resume.xls"');
header("Content-Transfer-Encoding;binary");
$objWriter->save('php;//output');
——————————————————————————————————————–
设置excel的属性:
创建人
$objPHPExcel->getProperties()->setCreator("Maarten Balliauw");
最后修改人
$objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");
标题
$objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");
题目
$objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");
描述
$objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");
关键字
$objPHPExcel->getProperties()->setKeywords("office 2007 openxml php");
种类
$objPHPExcel->getProperties()->setCategory("Test result file");
——————————————————————————————————————–
设置当前的sheet
$objPHPExcel->setActiveSheetIndex(0);
设置sheet的name
$objPHPExcel->getActiveSheet()->setTitle('Simple');
设置单元格的值
$objPHPExcel->getActiveSheet()->setCellValue('A1', 'String');
$objPHPExcel->getActiveSheet()->setCellValue('A2', 12);
$objPHPExcel->getActiveSheet()->setCellValue('A3', true);
$objPHPExcel->getActiveSheet()->setCellValue('C5', '=SUM(C2;C4)');
$objPHPExcel->getActiveSheet()->setCellValue('B8', '=MIN(B2;C5)');
合并单元格
$objPHPExcel->getActiveSheet()->mergeCells('A18;E22');
分离单元格
$objPHPExcel->getActiveSheet()->mergeCells('A18;E22');
$objPHPExcel->getActiveSheet()->mergeCells('A28;B28');
$objPHPExcel->getActiveSheet()->unmergeCells('A28;B28');
保护cell
$objPHPExcel->getActiveSheet()->getProtection()->setSheet(true); // Needs to be set to true in order to enable any worksheet protection!
$objPHPExcel->getActiveSheet()->protectCells('A3;E13', 'PHPExcel');
设置格式
// Set cell number formats
echo date('H;i;s') . " Set cell number formats\n";
$objPHPExcel->getActiveSheet()->getStyle('E4')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat;;FORMAT_CURRENCY_EUR_SIMPLE);
$objPHPExcel->getActiveSheet()->duplicateStyle( $objPHPExcel->getActiveSheet()->getStyle('E4'), 'E5;E13' );
设置宽width
// Set column widths
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setAutoSize(true);
$objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(12);
设置font
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setName('Candara');
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setSize(20);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setUnderline(PHPExcel_Style_Font;;UNDERLINE_SINGLE);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color;;COLOR_WHITE);
$objPHPExcel->getActiveSheet()->getStyle('E1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color;;COLOR_WHITE);
$objPHPExcel->getActiveSheet()->getStyle('D13')->getFont()->setBold(true);
$objPHPExcel->getActiveSheet()->getStyle('E13')->getFont()->setBold(true);
设置align
$objPHPExcel->getActiveSheet()->getStyle('D11')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment;;HORIZONTAL_RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('D12')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment;;HORIZONTAL_RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('D13')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment;;HORIZONTAL_RIGHT);
$objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment;;HORIZONTAL_JUSTIFY);
//垂直居中
$objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setVertical(PHPExcel_Style_Alignment;;VERTICAL_CENTER);
设置column的border
$objPHPExcel->getActiveSheet()->getStyle('A4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border;;BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('B4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border;;BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('C4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border;;BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('D4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border;;BORDER_THIN);
$objPHPExcel->getActiveSheet()->getStyle('E4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border;;BORDER_THIN);
设置border的color
$objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getLeft()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
$objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getRight()->getColor()->setARGB('FF993300');
设置填充颜色
$objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->setFillType(PHPExcel_Style_Fill;;FILL_SOLID);
$objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->getStartColor()->setARGB('FF808080');
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->setFillType(PHPExcel_Style_Fill;;FILL_SOLID);
$objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->getStartColor()->setARGB('FF808080');
加图片
$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName('Logo');
$objDrawing->setDescription('Logo');
$objDrawing->setPath('./images/officelogo.jpg');
$objDrawing->setHeight(36);
$objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
$objDrawing = new PHPExcel_Worksheet_Drawing();
$objDrawing->setName('Paid');
$objDrawing->setDescription('Paid');
$objDrawing->setPath('./images/paid.png');
$objDrawing->setCoordinates('B15');
$objDrawing->setOffsetX(110);
$objDrawing->setRotation(25);
$objDrawing->getShadow()->setVisible(true);
$objDrawing->getShadow()->setDirection(45);
$objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
在默认sheet后,创建一个worksheet
echo date('H;i;s') . " Create new Worksheet object\n";
$objPHPExcel->createSheet();
로그인 후 복사
3、EXCEL导入

require_once 'PHPExcel/IOFactory.php';
$inputFileName = 'ceshi.xls';
$objReader = new PHPExcel_Reader_Excel5();
$objPHPExcel = $objReader->load($inputFileName);
$sheet = $objPHPExcel->getSheet(0);
$highestRow = $sheet->getHighestRow(); // 取得总行数
$highestColumn = $sheet->getHighestColumn(); // 取得总列数

$tempArray = array();
for($j=2;$j<=$highestRow;$j++){
   for($k=&#39;A&#39;;$k<=$highestColumn;$k++){ 
    if($k==&#39;M&#39;$k==&#39;O&#39;) //M列和O列是时间
		$tempArray[] = excelTime($objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue());
	else
		$tempArray[] = $objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue();
	}
	print_r($tempArray);
	unset($tempArray);
}


function excelTime($date, $time = false) {
	if(function_exists(&#39;GregorianToJD&#39;)){
		if (is_numeric( $date )) {
		$jd = GregorianToJD( 1, 1, 1970 );
		$gregorian = JDToGregorian( $jd + intval ( $date ) - 25569 );
		$date = explode( &#39;/&#39;, $gregorian );
		$date_str = str_pad( $date [2], 4, &#39;0&#39;, STR_PAD_LEFT )
		."-". str_pad( $date [0], 2, &#39;0&#39;, STR_PAD_LEFT )
		."-". str_pad( $date [1], 2, &#39;0&#39;, STR_PAD_LEFT )
		. ($time ? " 00:00:00" : &#39;&#39;);
		return $date_str;
		}
	}else{
		$date=$date>25568?$date+1:25569;
		/*There was a bug if Converting date before 1-1-1970 (tstamp 0)*/
		$ofs=(70 * 365 + 17+2) * 86400;
		$date = date("Y-m-d",($date * 86400) - $ofs).($time ? " 00:00:00" : &#39;&#39;);
	}
  return $date;
}
로그인 후 복사





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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

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

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 개발: PHPExcel을 사용하여 Excel 파일 처리 PHP 개발: PHPExcel을 사용하여 Excel 파일 처리 Jun 15, 2023 pm 03:45 PM

디지털 시대의 도래와 함께 데이터는 우리의 일상과 업무에서 가장 중요한 부분이 되었고, 엑셀 파일은 데이터 처리를 위한 중요한 도구 중 하나가 되었습니다. 나는 많은 PHP 개발자들이 직장에서 데이터 처리 및 작업을 위해 Excel 파일을 사용하는 경우를 자주 접하게 될 것이라고 생각합니다. 이 글에서는 PHPExcel 라이브러리를 사용하여 Excel 파일을 처리하는 방법과 주의사항을 소개합니다. PHPExcel이란 무엇입니까? PHPExcel은 PHP 클래스입니다.

전체 가이드: PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하는 방법 전체 가이드: PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하는 방법 Jul 28, 2023 pm 10:01 PM

전체 가이드: PHP 확장을 사용하여 Excel 파일을 처리하는 방법 PHPExcel 소개: Excel 파일은 대용량 데이터 처리 및 통계 분석 시 데이터 저장 및 교환을 위한 일반적인 형식으로 사용되는 경우가 많습니다. PHP 확장 PHPExcel을 사용하면 Excel 파일을 쉽게 읽고, 쓰고, 수정하여 Excel 데이터를 효과적으로 처리할 수 있습니다. 이 기사에서는 PHP 확장 PHPExcel을 사용하여 Excel 파일을 처리하고 코드 예제를 제공하는 방법을 소개합니다. 1. PHPExc 설치

phpexcel을 사용하여 Excel 파일을 CSV 파일로 변환하고 여는 방법 phpexcel을 사용하여 Excel 파일을 CSV 파일로 변환하고 여는 방법 Mar 27, 2023 pm 04:16 PM

PHPEXCEL은 Excel 파일을 읽고 쓰는 데 탁월한 PHP 클래스 라이브러리입니다. PHP를 사용하여 Excel 파일을 읽고 쓸 수 있는 매우 충분한 API를 제공합니다. 경우에 따라 사용하기 위해 Excel 파일을 CSV 파일로 변환해야 하는 경우가 있습니다. 그래서 이번 글에서는 PHPEXCEL 클래스 라이브러리를 사용하여 엑셀 파일을 CSV 파일로 변환하고 여는 방법을 주로 설명합니다.

PHPExcel을 사용하여 Excel 파일을 처리하는 방법은 무엇입니까? PHPExcel을 사용하여 Excel 파일을 처리하는 방법은 무엇입니까? Jun 01, 2023 pm 02:01 PM

PHPExcel은 Microsoft Excel(.xls 및 .xlsx) 파일을 처리하기 위한 오픈 소스 PHP 라이브러리입니다. 엑셀 파일을 읽고 쓰고 조작할 수 있으며, 다양한 기능과 방법을 제공합니다. PHP 프로젝트에서 PHPExcel 라이브러리를 사용하면 Excel 파일을 빠르고 쉽게 처리하고 데이터 가져오기, 내보내기, 데이터 처리 등의 기능을 구현할 수 있습니다. 이 기사에서는 PHPExcel을 사용하여 Excel 파일을 처리하는 방법을 소개합니다. 1. PHPExcel을 설치하려면 다음을 사용하십시오.

PHP 및 PHPExcel을 사용하여 Excel 파일 만들기 PHP 및 PHPExcel을 사용하여 Excel 파일 만들기 May 11, 2023 am 08:40 AM

오늘날 급속한 정보 전송 시대에 데이터 처리 및 저장은 점점 더 중요해지고 있습니다. 많은 사람들이 엑셀 테이블을 가장 먼저 선택하는 이유는 엑셀 테이블이 다양한 데이터를 통합할 수 있고 쉽게 분석하고 처리할 수 있기 때문입니다. Excel 테이블 생성을 보다 효율적으로 완료하기 위해 PHP와 PHPExcel이라는 두 가지 강력한 도구를 사용할 수 있습니다. 이번 글에서는 PHP와 PHPExcel을 사용하여 Excel 파일을 만드는 방법을 소개하겠습니다. 1. 먼저 PHPExcel을 설치하세요

PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 Jul 02, 2023 pm 02:28 PM

PHP 개발 팁: PHPExcel 및 PHPExcel_IOFactory를 사용하여 MySQL 데이터베이스를 작동하는 방법 개요: 웹 개발에서 Excel 파일을 처리하는 것은 일반적이고 중요한 작업입니다. PHPExcel은 Excel 파일을 읽고 쓰는 데 도움이 되는 강력하고 사용하기 쉬운 PHP 라이브러리입니다. 이 기사에서는 PHPExcel 및 PHPExcel_IOFactory 라이브러리를 사용하여 MySQL 데이터베이스를 작동하는 방법을 소개합니다. 1 단계

phpexcel이 PHP 개발자의 초점이 된 이유 phpexcel이 PHP 개발자의 초점이 된 이유 Mar 27, 2023 pm 06:15 PM

PHPExcel은 Microsoft Excel 파일을 처리하기 위한 오픈 소스 PHP 라이브러리로 Excel 파일을 읽고, 만들고, 수정하고 저장할 수 있습니다. 데이터 분석, 보고서 생성, 데이터 가져오기 및 내보내기 등과 같은 작업을 처리하는 데 사용할 수 있는 강력하고 고도로 사용자 정의 가능한 도구입니다. 이 기사에서는 PHPExcel이 PHP 개발자의 중심이 된 이유를 소개합니다.

PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 작동하는 방법 PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 작동하는 방법 Jul 02, 2023 pm 12:21 PM

PHP 개발 기술: PHPExcel을 사용하여 MySQL 데이터베이스를 운영하는 방법 인터넷의 활발한 발전으로 인해 데이터베이스에 많은 양의 데이터가 저장되고 가져오기, 내보내기 및 처리와 같은 작업이 필요합니다. PHP 개발에서 PHPExcel은 Excel 파일과의 상호 작용을 단순화하고 데이터 가져오기 및 내보내기를 실현할 수 있는 강력한 라이브러리입니다. 이 기사에서는 PHPExcel을 사용하여 MySQL 데이터베이스를 작동하고 데이터 가져오기 및 내보내기 기능을 구현하는 방법을 소개합니다. PHPExcel 설치 및 구성

See all articles