php實(shí)現(xiàn)的操作excel類詳解
更新時(shí)間:2016年01月15日 09:39:15 作者:乘著風(fēng)在飛
這篇文章主要介紹了php實(shí)現(xiàn)的操作excel類,較為詳細(xì)的分析說(shuō)明了PHP操作excel的具體技巧,包括PHP針對(duì)excel的創(chuàng)建、打開、讀取、修改等,需要的朋友可以參考下
本文實(shí)例講述了php實(shí)現(xiàn)的操作excel類。分享給大家供大家參考,具體如下:
<?php
class Excel
{
static $instance=null;
private $excel=null;
private $workbook=null;
private $workbookadd=null;
private $worksheet=null;
private $worksheetadd=null;
private $sheetnum=1;
private $cells=array();
private $fields=array();
private $maxrows;
private $maxcols;
private $filename;
//構(gòu)造函數(shù)
private function Excel()
{
$this->excel = new COM("Excel.Application") or die("Did Not Connect");
}
//類入口
public static function getInstance()
{
if(null == self::$instance)
{
self::$instance = new Excel();
}
return self::$instance;
}
//設(shè)置文件地址
public function setFile($filename)
{
return $this->filename=$filename;
}
//打開文件
public function Open()
{
$this->workbook=$this->excel->WorkBooks->Open($this->filename);
}
//設(shè)置Sheet
public function setSheet($num=1)
{
if($num>0)
{
$this->sheetnum=$num;
$this->worksheet=$this->excel->WorkSheets[$this->sheetnum];
$this->maxcols=$this->maxCols();
$this->maxrows=$this->maxRows();
$this->getCells();
}
}
//取得表所有值并寫進(jìn)數(shù)組
private function getCells()
{
for($i=1;$i<$this->maxcols;$i++)
{
for($j=2;$j<$this->maxrows;$j++)
{
$this->cells[$this->worksheet->Cells(1,$i)->value][]=(string)$this->worksheet->Cells($j,$i)->value;
}
}
return $this->cells;
}
//返回表格內(nèi)容數(shù)組
public function getAllData()
{
return $this->cells;
}
//返回制定單元格內(nèi)容
public function Cell($row,$col)
{
return $this->worksheet->Cells($row,$col)->Value;
}
//取得表格字段名數(shù)組
public function getFields()
{
for($i=1;$i<$this->maxcols;$i++)
{
$this->fields[]=$this->worksheet->Cells(1,$i)->value;
}
return $this->fields;
}
//修改制定單元格內(nèi)容
public function editCell($row,$col,$value)
{
if($this->workbook==null || $this->worksheet==null)
{
echo "Error:Did Not Connect!";
}else{
$this->worksheet->Cells($row,$col)->Value=$value;
$this->workbook->Save();
}
}
//修改一行數(shù)據(jù)
public function editOneRow($row,$arr)
{
if($this->workbook==null || $this->worksheet==null || $row>=2)
{
echo "Error:Did Not Connect!";
}else{
if(count($arr)==$this->maxcols-1)
{
$i=1;
foreach($arr as $val)
{
$this->worksheet->Cells($row,$i)->Value=$val;
$i++;
}
$this->workbook->Save();
}
}
}
//取得總列數(shù)
private function maxCols()
{
$i=1;
while(true)
{
if(0==$this->worksheet->Cells(1,$i))
{
return $i;
break;
}
$i++;
}
}
//取得總行數(shù)
private function maxRows()
{
$i=1;
while(true)
{
if(0==$this->worksheet->Cells($i,1))
{
return $i;
break;
}
$i++;
}
}
//讀取制定行數(shù)據(jù)
public function getOneRow($row=2)
{
if($row>=2)
{
for($i=1;$i<$this->maxcols;$i++)
{
$arr[]=$this->worksheet->Cells($row,$i)->Value;
}
return $arr;
}
}
//關(guān)閉對(duì)象
public function Close()
{
$this->excel->WorkBooks->Close();
$this->excel=null;
$this->workbook=null;
$this->worksheet=null;
self::$instance=null;
}
};
/*
$excel = new COM("Excel.Application");
$workbook = $excel->WorkBooks->Open('D://Apache2//htdocs//wwwroot//MyExcel.xls');
$worksheet = $excel->WorkSheets(1);
echo $worksheet->Cells(2,6)->Value;
$excel->WorkBooks->Close();
*/
$excel=Excel::getInstance();
$excel->setFile("D://kaka.xls");
$excel->Open();
$excel->setSheet();
for($i=1;$i<16;$i++ )
{
$arr[]=$i;
}
//$excel->editOneRow(2,$arr);
//print_r($excel->getAllData());
$str=$excel->getAllData();
include_once('mail.class.php');
$smtpserver="smtp.yeah.net";
$smtpserverport=25;
$smtpuseremail="yanqihu58@yeah.net";
$smtpemailto="yanqihu@139.com";
$smtpuser="yanqihu58";
$smtppwd="123456789";
$mailtype="HTML";
$smtp=new smtp($smtpserver,$smtpserverport,true,$smtpuser,$smtppwd);
$message="你好";
//$message.="首頁(yè)連接地址為:".$this->link_url."<br>";
//$message.="電子郵箱為:".$this->link_email."<br>";
//$message.="商務(wù)聯(lián)系QQ:".$this->link_qq."<br>";
//$message.="商務(wù)電話QQ:".$this->link_tel."<br>";
//$message.="聯(lián)系人:".$this->link_people."<br>";
$smtp->debug=false;
foreach($str['email'] as $key=>$value){
$smtpemailto=$value;
@$smtp->sendmail($smtpemailto,$smtpuseremail,$mailsubject,$message,$mailtype);
exit;
}
//exit;
$excel->Close();
?>
更多關(guān)于PHP操作Excel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(jié)(包括word,excel,access,ppt)》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:
- php excel類 phpExcel使用方法介紹
- thinkPHP導(dǎo)出csv文件及用表格輸出excel的方法
- PHP使用PHPexcel導(dǎo)入導(dǎo)出數(shù)據(jù)的方法
- PHP導(dǎo)入導(dǎo)出Excel代碼
- php導(dǎo)出中文內(nèi)容excel文件類實(shí)例
- 用PHP生成excel文件到指定目錄
- PHPExcel中的一些常用方法匯總
- php導(dǎo)入excel文件到mysql數(shù)據(jù)庫(kù)的方法
- php生成excel列名超過(guò)26列大于Z時(shí)的解決方法
- Yii中使用PHPExcel導(dǎo)出Excel的方法
- ThinkPHP基于PHPExcel導(dǎo)入Excel文件的方法
相關(guān)文章
簡(jiǎn)單實(shí)現(xiàn)php上傳文件功能
這篇文章主要教大家如何簡(jiǎn)單實(shí)現(xiàn)php上傳文件功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09
php實(shí)現(xiàn)的Cookies操作類實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)的Cookies操作類及其用法實(shí)例,包括了常見了保存、讀取、更新及清除cookie等操作,在需要進(jìn)行cookie操作時(shí)非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-09-09
php實(shí)現(xiàn)的遍歷文件夾下所有文件,編輯刪除
遍歷文件夾; 功能:(a)可刪除文件 (b)可編輯文本,網(wǎng)頁(yè)文件 (c)可刪除文件夾,前提是該文件夾為空 (d)可建立文件,文件夾,修改文件夾名稱2010-01-01
PHP頁(yè)面靜態(tài)化的優(yōu)缺點(diǎn)與實(shí)現(xiàn)
眾所周知,頁(yè)面靜態(tài)化是門戶網(wǎng)站研發(fā)中必備的一項(xiàng)技能,本課程從純靜態(tài)化和偽靜態(tài)化兩個(gè)角度進(jìn)行分析,帶領(lǐng)大家掌握在PHP中如何生成純靜態(tài)化頁(yè)面,在WEB服務(wù)器中如何配置偽靜態(tài),幫助大家掌握又一項(xiàng)加薪利器2023-02-02

