liyaozhi
2025-10-28 1320688354fd168c51cf2e05f29a2253f4ed9c00
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
<?php
 
namespace app\agent\service\order;
 
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
 
/**
 * 订单导出服务类
 */
class ExportService
{
    /**
     * 订单导出
     */
    public function orderList($list)
    {
        $spreadsheet = new Spreadsheet();
        $sheet = $spreadsheet->getActiveSheet();
 
        //列宽
        $sheet->getColumnDimension('B')->setWidth(30);
        $sheet->getColumnDimension('P')->setWidth(30);
 
        //设置工作表标题名称
        $sheet->setTitle('订单明细');
 
        $sheet->setCellValue('A1', '订单号');
        $sheet->setCellValue('B1', '商品信息');
        $sheet->setCellValue('C1', '订单总额');
        $sheet->setCellValue('D1', '优惠券抵扣');
        $sheet->setCellValue('E1', '积分抵扣');
        $sheet->setCellValue('F1', '运费金额');
        $sheet->setCellValue('G1', '后台改价');
        $sheet->setCellValue('H1', '实付款金额');
        $sheet->setCellValue('I1', '支付方式');
        $sheet->setCellValue('J1', '下单时间');
        $sheet->setCellValue('K1', '买家');
        $sheet->setCellValue('L1', '买家留言');
        $sheet->setCellValue('M1', '配送方式');
        $sheet->setCellValue('N1', '自提门店名称');
        $sheet->setCellValue('O1', '自提联系人');
        $sheet->setCellValue('P1', '自提联系电话');
        $sheet->setCellValue('Q1', '收货人姓名');
        $sheet->setCellValue('R1', '联系电话');
        $sheet->setCellValue('S1', '收货人地址');
        $sheet->setCellValue('T1', '物流公司');
        $sheet->setCellValue('U1', '物流单号');
        $sheet->setCellValue('V1', '付款状态');
        $sheet->setCellValue('W1', '付款时间');
        $sheet->setCellValue('X1', '发货状态');
        $sheet->setCellValue('Y1', '发货时间');
        $sheet->setCellValue('Z1', '收货状态');
        $sheet->setCellValue('AA1', '收货时间');
        $sheet->setCellValue('AB1', '订单状态');
        $sheet->setCellValue('AC1', '微信支付交易号');
        $sheet->setCellValue('AD1', '是否已评价');
 
        //填充数据
        $index = 0;
        foreach ($list as $order) {
            $address = $order['address'];
            $sheet->setCellValue('A'.($index + 2), "\t".$order['order_no']."\t");
            $sheet->setCellValue('B'.($index + 2), $this->filterProductInfo($order));
            $sheet->setCellValue('C'.($index + 2), $order['total_price']);
            $sheet->setCellValue('D'.($index + 2), $order['coupon_money']);
            $sheet->setCellValue('E'.($index + 2), $order['points_money']);
            $sheet->setCellValue('F'.($index + 2), $order['express_price']);
            $sheet->setCellValue('G'.($index + 2), "{$order['update_price']['symbol']}{$order['update_price']['value']}");
            $sheet->setCellValue('H'.($index + 2), $order['pay_price']);
            $sheet->setCellValue('I'.($index + 2), $order['pay_type']['text']);
            $sheet->setCellValue('J'.($index + 2), $order['create_time']);
            $sheet->setCellValue('K'.($index + 2), $order['user']['nickName']);
            $sheet->setCellValue('L'.($index + 2), $order['buyer_remark']);
            $sheet->setCellValue('M'.($index + 2), $order['delivery_type']['text']);
            $sheet->setCellValue('N'.($index + 2), !empty($order['extract_store']) ? $order['extract_store']['shop_name'] : '');
            $sheet->setCellValue('O'.($index + 2), !empty($order['extract']) ? $order['extract']['linkman'] : '');
            $sheet->setCellValue('P'.($index + 2), !empty($order['extract']) ? $order['extract']['phone'] : '');
            $sheet->setCellValue('Q'.($index + 2), $order['address']['name']);
            $sheet->setCellValue('R'.($index + 2), $order['address']['phone']);
            $sheet->setCellValue('S'.($index + 2), $address ? $address->getFullAddress() : '');
            $sheet->setCellValue('T'.($index + 2), $order['express']['express_name']);
            $sheet->setCellValue('U'.($index + 2), $order['express_no']);
            $sheet->setCellValue('V'.($index + 2), $order['pay_status']['text']);
            $sheet->setCellValue('W'.($index + 2), $this->filterTime($order['pay_time']));
            $sheet->setCellValue('X'.($index + 2), $order['delivery_status']['text']);
            $sheet->setCellValue('Y'.($index + 2), $this->filterTime($order['delivery_time']));
            $sheet->setCellValue('Z'.($index + 2), $order['receipt_status']['text']);
            $sheet->setCellValue('AA'.($index + 2), $this->filterTime($order['receipt_time']));
            $sheet->setCellValue('AB'.($index + 2), $order['order_status']['text']);
            $sheet->setCellValue('AC'.($index + 2), $order['transaction_id']);
            $sheet->setCellValue('AD'.($index + 2), $order['is_comment'] ? '是' : '否');
            $index ++;
        }
 
        //保存文件
        $writer = new Xlsx($spreadsheet);
        $filename = iconv("UTF-8","GB2312//IGNORE", '订单'). '-' . date('YmdHis') . '.xlsx';
 
 
        header('Content-Type: application/vnd.ms-excel');
        header('Content-Disposition: attachment;filename="'.$filename.'"');
        header('Cache-Control: max-age=0');
        $writer = IOFactory::createWriter($spreadsheet, 'Xlsx');
        $writer->save('php://output');
    }
 
    /**
     * 格式化商品信息
     */
    private function filterProductInfo($order)
    {
        $content = '';
        foreach ($order['product'] as $key => $product) {
            $content .= ($key + 1) . ".商品名称:{$product['product_name']}\n";
            !empty($product['product_attr']) && $content .= " 商品规格:{$product['product_attr']}\n";
            $content .= " 购买数量:{$product['total_num']}\n";
            $content .= " 商品总价:{$product['total_price']}元\n\n";
        }
        return $content;
    }
 
 
    /**
     * 日期值过滤
     */
    private function filterTime($value)
    {
        if (!$value) return '';
        return date('Y-m-d H:i:s', $value);
    }
 
}