php 导出多个excel并输出压缩文件

set_time_limit(0); ob_end_clean(); header('Content-Encoding: none'); header('Content-Type: application/octet-stream'); header('Content-Disposition: attachment; filename='.$fileName);...
摘要由CSDN通过智能技术生成
set_time_limit(0);
    ob_end_clean();
    header('Content-Encoding: none');
    header('Content-Type: application/octet-stream');
    header('Content-Disposition: attachment; filename='.$fileName);
    header('Pragma: no-cache');
    header('Expires: 0');

    //查询数据库中唯一的省份
    $distinct_company = C::t('common_usercompany')->fetch_distinct_company_exportall();
    $arr = [];
    $fileNameArr = array();

    //每个省份导出一个excel
    foreach ($distinct_company as $key => $value) {
        $uids = C::t('common_usercompany')->fetch_all_conpany_users($value);
        $detail = '';
        //excel的header头
        $title = array('UID','用户名','member_type'=> '用户类型','field1' => '','mobile' => '', 'company'=>'公司','company_address' => '公司区域','stock_code'=>'公司代码', 'gender' => '', 'birthyear' => '', 'birthmonth' => '', 'birthday' => '',
            'address' => '',  'bio' => '',  'auth_completed' => '是否验证');
        foreach(C::t('common_member_profile_setting')->range() as $v1) {
            if(isset($title[$v1['fieldid']])) {
                $title[$v1['fieldid']] = $v1['title'];
            }
        }

        //如果该省份下有注册的用户,则输出excel表
        if($uids && is_array($uids)) {
            $arr[] = $uids;
            $allprofile = C::t('common_member_profile')->fetch_all($uids);
            $company = C::t('common_usercompany')->fetch_by_province($value);
            $allusername = C::t('common_member')->fetch_all_by_uid($uids);
            $member_types = get_member_type();

            //生成临时文件
            $filename = $company['province'].'.csv';
            $filename = iconv("UTF-8","GBK//IGNORE",$filename);
            $fp = fopen($filename, 'w'
  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1.获取PHPExcel 2.添加如下方法: function Excel_Export($filename,$data,$sheet){ error_reporting(E_ALL); ini_set('display_errors','On'); /** Include path **/ set_include_path(get_include_path() . PATH_SEPARATOR . '../Classes/'); /** PHPExcel */ include 'api/excel/PHPExcel.php'; /** PHPExcel_Writer_Excel2007 */ include 'api/excel/PHPExcel/Writer/Excel2007.php'; // Create new PHPExcel object //echo date('H:i:s') . "Create new PHPExcel object\n"; $objPHPExcel = new PHPExcel(); // Set properties //echo date('H:i:s') . "Set properties\n"; $objPHPExcel->getProperties()->setCreator("E421083458"); $objPHPExcel->getProperties()->setLastModifiedBy("E421083458"); $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document"); $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document"); $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes."); $objPHPExcel->getProperties()->setKeywords("office 2007 openxml php"); $objPHPExcel->getProperties()->setCategory("Test result file"); // Add some data //echo date('H:i:s') . "Add some data\n"; $objPHPExcel->setActiveSheetIndex(0); $charlist = 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"); //print_r($data); foreach($data as $key=>$value){ $j=0; if($key==0){ foreach($value as $k=>$v){ if($j<25){ $objPHPExcel->getActiveSheet()->setCellValue($charlist[$j].($key+1), mb_convert_encoding($k, "UTF-8", "GBK")); $j++; } } $j=0; } foreach($value as $k=>$v){ if($j<25){ //echo $charlist[$j].($key+1)."<br/>"; //echo $v."<br/>"; $objPHPExcel->getActiveSheet()->setCellValue($charlist[$j].($key+2), mb_convert_encoding($v, "UTF-8", "GBK")); $j++; } } } // Rename sheet //echo date('H:i:s') . "Rename sheet\n"; $objPHPExcel->getActiveSheet()->setTitle(mb_convert_encoding($sheet,

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值