拿走系列,直接上代码:
/**
* 导出数据至Excel
* @author Aihy
* @email 202683457@qq.com
*/
public function outputData()
{
// 导出文件名
$excelName = 'Excel文件名';
// 导出数据(二维数组)
$excelData = array(
array(1024,'http://www.7l7y.com','7Y'),
array(2048,'http://www.aihy.top','7Y'),
);
// 生成Excel文件
$this->_exportexcel($excelData,array('编号','网址','备注'),$excelName);
}
/**
* 导出数据为excel表格
* @param array $data 一个二维数组,结构如同从数据库查出来的数组
* @param array $title excel的第一行标题,一个数组,如果为空则没有标题
* @param string $filename 下载的文件名
* @author Aihy
* @email 202683457@qq.com
*/
public function _exportExcel($data = array() , $title = array() , $filename='report')
{
header("Content-Type: text/html; charset=UTF-8");
header("Content-type:application/octet-stream");
header("Accept-Ranges:bytes");
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=".$filename.".xls");
header("Pragma: no-cache");
header("Expires: 0");
// 导出xls 开始
if (!empty($title))
{
foreach ($title as $k => $v)
{
$title[$k] = iconv("UTF-8", "GB2312",$v);
}
$title= implode("\t", $title);
echo "$title\n";
}
if (!empty($data))
{
foreach($data as $key => $val)
{
foreach ($val as $ck => $cv)
{
$data[$key][$ck] = iconv("UTF-8", "GB2312", $cv);
}
$data[$key] = implode("\t", $data[$key]);
}
echo implode("\n",$data);
}
}
最终输出结果如下:
导出文件:
Excel内容: