/** * excel导出类 * * 使用方法 $excel=new Excel(); * //设置编码: *$excel->setEncode("utf-8","gb2312"); //如果不转码,参数写一样即可,例如$excel->setEncode("utf-8","utf-8"); * //设置标题栏 * $titlearr=array("a","b","c","d"); * //设置内容栏 * $contentarr=array( * 1=>array("ab","ac","ad","ae"), * 2=>array("abc","acc","adc","aec"), * 3=>array("abd","acd","add","aed"), * 4=>array("abe","ace","ade","aee"), * ); * $excel->getExcel($titlearr,$contentarr,"abc"); */ class Excel { var $inEncode; //一般是页面编码 var $outEncode; //一般是Excel文件的编码 public function __construct(){ } /** *设置编码 */ public function setEncode($incode,$outcode){ $this->inEncode=$incode; $this->outEncode=$outcode; } /** *设置Excel的标题栏 */ public function setTitle($titlearr){ $title=""; foreach($titlearr as $v){ if($this->inEncode!=$this->outEncode){ $title.=iconv($this->inEncode,$this->outEncode,$v)."\t"; } else{ $title.=$v."\t"; } } $title.="\n"; return $title; } /** *设置Excel内容 */ public function setRow($array){ $content=""; foreach($array as $k => $v){ foreach($v as $vs){ if($this->inEncode!=$this->outEncode){ $content.=iconv($this->inEncode,$this->outEncode,$vs)."\t"; } else{ $content.=$vs."\t"; } } $content.="\n"; } return $content; } /** *生成并自动下载Excel * $titlearr 标题栏数组 * $array 内容数组 * $filename 文件名称 (为空,已当前日期为名称) */ public function getExcel($titlearr,$array,$filename=''){ if($filename==''){ $filename=date("Y-m-d"); } $title=$this->setTitle($titlearr); $content=$this->setRow($array); header("Content-type:application/vnd.ms-excel"); header("Content-Disposition:filename=".$filename.".xls"); echo $title; echo $content; } }