php 导出csv格式的数据

    /**
     * 导出店铺csv
     */
    public function export_csv(){
        $where = array();//搜索条件

        $shop_name = I('shop_name');//接收搜索条件
        $manager_name = I('manager_name');
        $order_ids = I('order_ids');
        if($shop_name){
            $where['shop_name'] = ['like','%'.$shop_name.'%'];
        }
        if($manager_name){
            $where['manager_name'] = ['like','%'.$manager_name.'%'];
        }
        if($order_ids){
            $where['id'] = ['in', $order_ids];
        }

        $userList = M('shop')->where($where)->order('id')->limit($start.','.$end)->select();//查出需要导出的数据

        header('Content-Type: application/vnd.ms-excel');   //header设置
        header("Content-Disposition: attachment;filename=".$fileName.".csv");
        header('Cache-Control: max-age=0');

        $fp = fopen('php://output','a');    //打开php文件句柄,php://output表示直接输出到PHP缓存,a表示将输出的内容追加到文件末尾

        $head = array('店铺ID','店铺名称','掌柜ID','累计订单任务量','完成任务量','订单任务金额','实际完成任务金额');  //表头信息
        foreach($head as $k=>$v){
            $head[$k] = iconv("UTF-8","GBK//IGNORE",$v);    //将utf-8编码转为gbk。理由是: Excel 以 ANSI 格式打开,不会做编码识别。如果直接用 Excel 打开 UTF-8 编码的 CSV 文件会导致汉字部分出现乱码。  
        }
        fputcsv($fp,$head);  //fputcsv() 函数将行格式$head化为 CSV 并写入一个打开的文件$fp。 

        if (!empty($userList)) {  
            $data = [];  //要导出的数据的顺序与表头一致;提前将最后的值准备好(比如:时间戳转为日期等)
            foreach ($userList as $key => $val) {
                $data['id'] = "xm-".$val['id'];
                $data['shop_name'] = $val['shop_name'];
                $data['manager_name'] = $val['manager_name'];
                $data['task_num'] = $val['task_num'];
                $data['finish_task'] = $val['finish_task'];
                $data['all_money'] = (float)$val['all_money'];
                $data['finish_money'] = $val['finish_money'];

                foreach($data as $i=> $item){  //$item为一维数组哦
                    $data[$i] = iconv("UTF-8","GBK//IGNORE",$item);  //转为gbk的时候可能会遇到特殊字符‘-’之类的会报错,加 ignore表示这个特殊字符直接忽略不做转换。
                }
                fputcsv($fp,$data);
            }
            exit;  //记得加这个,不然会跳转到某个页面。
        }

    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用PhpSpreadsheet导出CSV文件,你需要按照以下步骤进行操作: 1. 首先,导入所需的类和命名空间。你需要导入`PhpOffice\PhpSpreadsheet\Spreadsheet`和`PhpOffice\PhpSpreadsheet\Writer\Csv`类。你可以使用以下代码导入它们: ```php use PhpOffice\PhpSpreadsheet\Spreadsheet; use PhpOffice\PhpSpreadsheet\Writer\Csv; ``` 2. 创建一个新的`Spreadsheet`对象,并设置你的数据。你可以使用`getActiveSheet()`方法获取当前活动的工作表,并使用`setCellValue()`方法设置单元格的值。例如,你可以使用以下代码设置A1单元格的值为"Hello World": ```php $spreadsheet = new Spreadsheet(); $sheet = $spreadsheet->getActiveSheet(); $sheet->setCellValue('A1', 'Hello World'); ``` 3. 创建一个`Csv`写入器对象,并将`Spreadsheet`对象传递给它。然后,使用`save()`方法将数据保存为CSV文件。你可以指定保存的文件路径和文件名。例如,你可以使用以下代码将数据保存为名为"output.csv"的CSV文件: ```php $writer = new Csv($spreadsheet); $writer->save('output.csv'); ``` 请注意,以上代码只是一个示例,你可以根据自己的需求进行修改和扩展。确保在使用PhpSpreadsheet之前,你已经安装了它并将其包含在你的项目中。 希望这可以帮助到你! #### 引用[.reference_title] - *1* [fastadmin+phpspreadsheet实现导出和导入](https://blog.csdn.net/Jian_Sir/article/details/130004153)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值