php读取execl 实例,php读取excel的实例代码
之前我們介紹了php寫(xiě)excel文件的實(shí)現(xiàn)代碼,今天我們介紹使用PHPExcel讀取excel文件,讀取出的文件包含標(biāo)題欄等信息的方法。
注意:單元格第一行以1開(kāi)始,第一列以0開(kāi)始
代碼:
/**
* php 讀取excel文件
* edit by www.jbxue.com
*/
require_once 'PHPExcel.php';
require_once 'PHPExcel/IOFactory.php';
class ExcelHelper{
public function importFileContacts($filename){
try {
//解決文件中文名問(wèn)題
$filename = iconv("UTF-8","GB2312",$filename);
if (!file_exists($filename)) {
return false;
}
//chmod($filename, 0750);linux下改變文件權(quán)限
$filetype = $this->getFileType($filename);
//根據(jù)文件類型讀取excel文件
if ($filetype == "xlsx") {
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
$objReader->setReadDataOnly(true);
} elseif ($filetype == "xls") {
$objReader = PHPExcel_IOFactory::createReader('Excel5');
$objReader->setReadDataOnly(true);
} else {
return false;
}
$mems = NULL;
$objPHPExcel = $objReader->load($filename);
$objWorksheet = $objPHPExcel->getActiveSheet();
$highestRow = $objWorksheet->getHighestRow(); // e.g. 10
$highestColumn = $objWorksheet->getHighestColumn(); // e.g 'F'
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn); // e.g. 5
for ($row = 1; $row <= $highestRow; $row++) {
for ($col = 0; $col < $highestColumnIndex; $col++) {
$mem[$col] = trim($objWorksheet->getCellByColumnAndRow($col, $row)->getValue());
}
$mems[$row - 1] = $mem;
}
return $mems;
} catch (Exception $e) {
echo 'EXCEL ERROR:' . $e->getMessage();
$errText = "Read excel error:Please retry later!";
return $errText;
}
}
/**
* 獲取文件類型
* @param $filenamePath 文件路徑或者文件名
*/
private function getFileType($filenamePath){
if (!$filenamePath){
return false;
}
$filenameArr = explode('/', $filenamePath);
$count = count($filenameArr);
$filename = $filenameArr[$count-1];
$filetypeArr = explode('.', $filename);
$count = count($filetypeArr);
$filetype = $filetypeArr[$count-1];
return $filetype;
}
}
?>
總結(jié)
以上是生活随笔為你收集整理的php读取execl 实例,php读取excel的实例代码的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 无需依赖Adobe Acrobat,在J
- 下一篇: c语言实现通讯录(详解)