"; /** * excel页脚 * 依照excel xml规范。 * * @access private * @var string */ private $footer = ""; /** * 文档行(行数组中) * * @access private * @var array */ private $lines = array (); /** * 工作表(数组) * * @access private * @var array */ private $worksheets = array (); /** * 单元格样式 * @access private * @var string */ private $cellstyle = array(); /** * 默认单元格数据格式 * @access private * @var string */ private $default_cellformat = "String"; public function __construct(){ //设置默认样式 $this->cellstyle['Default'] = ''; } /** * 添加单行数据 * * @access private * @param array 1维数组 * @todo 行创建 */ private function addRow ($array) { //初始化单元格 $cells = ""; //构建单元格 foreach ($array as $k => $v){ $style_str = ''; if(!empty($v['styleid'])){ $style_str = 'ss:StyleID="'.$v['styleid'].'"'; } $format_str = $this->default_cellformat; if(!empty($v['format'])){ $format_str = $v['format']; } $cells .= "{$v['data']}\n"; } //构建行数据 $this->lines[] = "\n" . $cells . "\n"; } /** * 添加多行数据 * @access public * @param array 2维数组 * @todo 构造多行 */ public function addArray ($array) { $this->lines = array(); //构建行数据 foreach ((array)$array as $k => $v){ $this->addRow ($v); } } /** * 添加工作表 * @access public * @param string $sheettitle 工作表名 * @todo 构造工作表XML */ public function addWorksheet($sheettitle) { //剔除特殊字符 $sheettitle = preg_replace ("/[\\\|:|\/|\?|\*|\[|\]]/", "", $sheettitle); //现在,将其减少到允许的长度 //$sheettitle = substr ($sheettitle, 0, 50); $this->worksheets[] = "\n\n\n". "\n". implode ("\n", $this->lines). "
\n
\n"; } /** * 设置单元格样式 * * @access public * @param array 样式数组例如: array('id'=>'s_title','Font'=>array('FontName'=>'宋体','Size'=>'12','Bold'=>'1')); * 当id为Default时,为表格的默认样式 */ public function setStyle ($style_arr){ if(empty($style_arr)){ return false; } $id = $style_arr['id']; unset($style_arr['id']); $style_str = "'; } /** * 设置默认单元格格式 * * @access public * @param string */ public function setDefaultFormat ($format_str){ if(empty($style_arr)){ return false; } $this->default_cellformat = $format_str; } /** * 生成excel文件 * 最后生成excel文件,并使用header()函数来将它交付给浏览器。 * @access public * @param string $filename 文件名称 */ public function generateXML ($filename) { $encoded_filename = urlencode($filename); $encoded_filename = str_replace("+", "%20", $encoded_filename); //头 $ua = $_SERVER["HTTP_USER_AGENT"]; header("Content-Type: application/vnd.ms-excel"); if(preg_match("/MSIE/", $ua)){ header('Content-Disposition: attachment; filename="'.$encoded_filename.'.xls"'); }else if(preg_match("/Firefox/", $ua)){ header('Content-Disposition: attachment; filename*="utf8\'\''.$filename.'.xls"'); }else{ header('Content-Disposition: attachment; filename="'.$filename.'.xls"'); } header('Cache-Control: max-age=0'); echo stripslashes ($this->header); //样式 echo "\n"; foreach((array)$this->cellstyle as $k=>$v){ echo "\n".$v; } echo "\n"; //工作表 echo implode ("\n", $this->worksheets); echo $this->footer; } /** * 转码函数 * * @param mixed $content * @param string $from * @param string $to * @return mixed */ public function charset($content, $from='gbk', $to='utf-8') { $from = strtoupper($from) == 'UTF8' ? 'utf-8' : $from; $to = strtoupper($to) == 'UTF8' ? 'utf-8' : $to; if (strtoupper($from) === strtoupper($to) || empty($content)) { //如果编码相同则不转换 return $content; } if (function_exists('mb_convert_encoding')) { if (is_array($content)){ $content = var_export($content, true); $content = mb_convert_encoding($content, $to, $from); eval("\$content = $content;");return $content; }else { return mb_convert_encoding($content, $to, $from); } } elseif (function_exists('iconv')) { if (is_array($content)){ $content = var_export($content, true); $content = iconv($from, $to, $content); eval("\$content = $content;");return $content; }else { return iconv($from,$to,$content); } } else { return $content; } } } ?>