700字范文,内容丰富有趣,生活中的好帮手!
700字范文 > Php生成货运交接单excel表 php 订单导出到excel表格及乱码问题

Php生成货运交接单excel表 php 订单导出到excel表格及乱码问题

时间:2019-04-15 08:03:12

相关推荐

Php生成货运交接单excel表 php 订单导出到excel表格及乱码问题

public function outExcelRecharge() {

$list = M(‘Order’)

->table(‘__ORDER__ as o’)

->join(‘__USER__ as u on u.id=o.user_id’)

->join(‘__STUDENT__ as s on s.student_id=o.student_id’,’left’)

->field(‘o.order_id,u.nickname,o.total_price,o.add_time,o.order_no,o.status,o.goods_title,s.child_name,s.phone,s.child_birthday’)

// ->where($where)

->order(‘o.add_time desc’)

->select();

foreach ($list as &$value) {

$value[‘add_time’] = date(“Y-m-d H:i:s”, $value[‘add_time’]);

$value[‘status’] = $value[‘status’] == 2 ? ‘已付款’ : ‘未付款’;

}

$field = array(

array(‘order_id’, ‘ ID’),

array(‘nickname’, ‘微信昵称’),

array(‘goods_title’, ‘商品标题’),

array(‘total_price’, ‘总价’),

array(‘order_no’, ‘订单号’),

array(‘add_time’, ‘下单时间’),

array(‘status’, ‘状态’),

array(‘child_name’, ‘姓名’),

array(‘phone’, ‘电话’),

array(‘child_birthday’, ‘生日’),

);

$this->exportExcel(‘订单列表_’ . date(‘Y-m-d’), $field, $list);

}

//导出操作

public function exportExcel($expTitle, $expCellName, $expTableData) {

$xlsTitle = iconv(‘utf-8’, ‘gb2312’, $expTitle); //文件名称

$fileName = $expTitle . date(‘_Ymd_His’); //or $xlsTitle 文件名称可根据自己情况设定

$cellNum = count($expCellName);

$dataNum = count($expTableData);

import(“Org.Util.PHPExcel”);

import(“Org.Util.PHPExcel.Writer.Excel5”);

import(“Org.Util.PHPExcel.IOFactory.php”);

$objPHPExcel = new \PHPExcel();

$cellName = array(‘A’, ‘B’, ‘C’, ‘D’, ‘E’, ‘F’, ‘G’, ‘H’, ‘I’, ‘J’, ‘K’, ‘L’, ‘M’, ‘N’, ‘O’, ‘P’, ‘Q’, ‘R’, ‘S’, ‘T’, ‘U’, ‘V’, ‘W’, ‘X’, ‘Y’, ‘Z’, ‘AA’, ‘AB’, ‘AC’, ‘AD’, ‘AE’, ‘AF’, ‘AG’, ‘AH’, ‘AI’, ‘AJ’, ‘AK’, ‘AL’, ‘AM’, ‘AN’, ‘AO’, ‘AP’, ‘AQ’, ‘AR’, ‘AS’, ‘AT’, ‘AU’, ‘AV’, ‘AW’, ‘AX’, ‘AY’, ‘AZ’);

$objPHPExcel->getActiveSheet(0)->mergeCells(‘A1:’ . $cellName[$cellNum – 1] . ‘1’); //合并单元格

$objPHPExcel->setActiveSheetIndex(0)->setCellValue(‘A1’, $expTitle . ‘ Export time:’ . date(‘Y-m-d H:i:s’)); //第一行标题

for ($i = 0; $i < $cellNum; $i++) {

$objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i] . ‘2’, $expCellName[$i][1]);

}

// Miscellaneous glyphs, UTF-8

for ($i = 0; $i < $dataNum; $i++) {

for ($j = 0; $j < $cellNum; $j++) {

$objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]]);

}

}

ob_end_clean();

header(‘pragma:public’);

header(‘Content-type:application/vnd.ms-excel;charset=utf-8;name=”‘ . $xlsTitle . ‘.xls”‘);

header(“Content-Disposition:attachment;filename=$fileName.xls”); //attachment新窗口打印inline本窗口打印

$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, ‘Excel5’);

$objWriter->save(‘php://output’);

exit;

}

如果导出乱码:

在导出前面加上:ob_end_clean();

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。