PHP怎么导出报表

这篇文章主要介绍“PHP怎么导出报表”,在日常操作中,相信很多人在PHP怎么导出报表问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP怎么导出报表”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

创新互联2013年至今,是专业互联网技术服务公司,拥有项目网站设计制作、网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元锦江做网站,已为上家服务,为锦江各地企业和个人服务,联系电话:13518219792

效果

PHP怎么导出报表

PHP怎么导出报表

需求

为了实现报表效果,自己杜撰的需求。

主要是思路,思路通了实现其他效果也OK。

统计每个人在一年中每一天迟到早退的情况。

思路

用 PHP 语言进行实现。

首先将报表样式用 HTML 实现,

然后利用PHP header 函数生成 xls 下载。

知识点

  • 表格中的列合并与行合并

  • PHP 获取一年中的每一天进行展示

  • PHP header 函数

  • Smarty 模板函数

  • Smarty 自定义函数

  • ...

PHP 代码

public function export()
{

    //获取2016年日期
    $time_start = strtotime('2016-01-01');
    $time_end   = strtotime('2016-12-31');

    $month_arr = [];
    $month_arr['month'][]   = '2016-01';
    $month_arr['numbers'][] = date('t',$time_start); //获取天数

    while (($time_start = strtotime('+1 month', $time_start)) <= $time_end) {
        $month_arr['month'][]   = date('Y-m',$time_start); //取得递增月
        $month_arr['numbers'][] = date('t',$time_start);     //获取天数
    }

    function check_week($time = [])
    {
        if (empty($time['day'])) {
            return '';
        }
        $w = intval(date('w' , strtotime($time['day'])));
        if( $w === 0 || $w === 6){
            return ''
                  .date('d', strtotime($time['day']))
                  .'';        }        return ''.date('d', strtotime($time['day'])).'';    }    //向模板中注册一个函数    $this->smarty->registerPlugin('function','check_week','check_week');    //模拟数据如下:    $list[0]['name'] = 'Tom';    $list[1]['name'] = 'Joan';    $list[0]['sex'] = '男';    $list[1]['sex'] = '女';    $list[0]['age'] = '30';    $list[1]['age'] = '31';    //设置迟到    $list[0]['late'] = [        '2016-01-08',        '2016-01-09',        '2016-02-09',        '2016-03-09',        '2016-04-09',        '2016-05-09'    ];    $list[1]['late'] = [        '2016-02-12',        '2016-03-15',        '2016-04-13',        '2016-05-19',        '2016-05-19'    ];    //设置早退    $list[0]['leave'] = [        '2016-03-09',        '2016-04-11',        '2016-05-15',        '2016-06-18',        '2016-07-21',        '2016-08-23',        '2016-09-22',        '2016-10-20',        '2016-11-17',        '2016-12-14',    ];    $list[1]['leave'] = [        '2016-05-09',        '2016-06-11',        '2016-07-13',        '2016-08-15',        '2016-09-17',        '2016-10-19',        '2016-11-20',        '2016-12-23',        '2016-03-18',        '2016-02-19',        '2016-01-23',    ];    $file_name   = "报表-".date("YmdHis",time());    $file_suffix = "xls";    header("Content-Type: application/vnd.ms-excel");    header("Content-Disposition: attachment; filename=$file_name.$file_suffix");    $this->_assign('list', $list);    $this->_assign('month', $month_arr);    $this->_display(); }

HTML 代码




    
    
    




    
        
        
        
        {if $month}
            {foreach $month.month as $k=>$m}
                
            {/foreach}
        {/if}
    
    
        {if $month}
        {foreach $month.month as $k=>$m}
            {section name=count loop=$month.numbers.$k+1 start=1}
                {check_week day=$m|cat:"-"|cat:$smarty.section.count.index}
            {/section}
        {/foreach}
        {/if}
    

    {if $list}
    {foreach $list as $s}
    
        
        
        
        {if $month}
        {foreach $month.month as $k=>$m}
            {section name=count loop=$month.numbers.$k+1 start=1}
                {if $smarty.section.count.index <10 }
                     {$str = ""}
                     {$smarty.section.count.index = $str|cat:"0"|cat:$smarty.section.count.index}
                {/if}
                

            {/section}
        {/foreach}
        {/if}
    
    {/foreach}
    
        
        
    
    
        
        
    
    
        
        
    
    
        
        
    
    {/if}

           姓名
       

           性别
       

           年龄
       

                   {$m}
               
{$s.name|default:'--'}{$s.sex|default:'--'}{$s.age|default:'--'}                {if $s['late']}                    {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['late']}                        1                    {/if}                {/if}                {if $s['leave']}                    {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['leave']}                        1                    {/if}                {/if}                
*周末
*正常
*迟到
*早退

到此,关于“PHP怎么导出报表”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


本文题目:PHP怎么导出报表
文章出自:http://myzitong.com/article/ghjcss.html