PHP导出报表(案例)

作者: 新亮笔记 | 来源:发表于2017-01-16 13:51 被阅读190次

效果

报表.png 报表.gif

需求

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

主要是思路,思路通了实现其他效果也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 '<td style="background-color: red;">'.date('d', strtotime($time['day'])).'</td>';
        }
        return '<td>'.date('d', strtotime($time['day'])).'</td>';
    }

    //向模板中注册一个函数
    $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 代码

<html xmlns:o="urn:schemas-microsoft-com:office:office"
      xmlns:x="urn:schemas-microsoft-com:office:excel"
      xmlns="http://www.w3.org/TR/REC-html40">

<head>
    <meta http-equiv=Content-Type content="text/html; charset=utf-8">
    <meta name=ProgId content=Excel.Sheet>
    <meta name=Generator content="Microsoft Excel 11">
</head>

<body>
<table border=1 cellpadding=0 cellspacing=0 width="100%">
    <tr>
        <td style="vertical-align:middle;" align="center" rowspan="2"><b>姓名</b></td>
        <td style="vertical-align:middle;" align="center" rowspan="2"><b>性别</b></td>
        <td style="vertical-align:middle;" align="center" rowspan="2"><b>年龄</b></td>
        {if $month}
            {foreach $month.month as $k=>$m}
                <td style="text-align: center;" colspan="{$month.numbers.$k}"><b>{$m}</b></td>
            {/foreach}
        {/if}
    </tr>
    <tr>
        {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}
    </tr>

    {if $list}
    {foreach $list as $s}
    <tr>
        <td>{$s.name|default:'--'}</td>
        <td>{$s.sex|default:'--'}</td>
        <td>{$s.age|default:'--'}</td>
        {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}
                <td style="
                    {if $s['late']}
                        {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['late']}
                            background-color: #5a0099;
                        {/if}
                    {/if}

                    {if $s['leave']}
                        {if ($m|cat:"-"|cat:$smarty.section.count.index)|in_array:$s['leave']}
                            background-color: yellow;
                        {/if}
                    {/if}
                ">

                {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}

                </td>

            {/section}
        {/foreach}
        {/if}
    </tr>
    {/foreach}
    <tr>
        <td style="background-color: red"></td>
        <td>*周末</td>
    </tr>
    <tr>
        <td style="background-color: white"></td>
        <td>*正常</td>
    </tr>
    <tr>
        <td style="background-color: #5a0099"></td>
        <td>*迟到</td>
    </tr>
    <tr>
        <td style="background-color: yellow"></td>
        <td>*早退</td>
    </tr>
    {/if}
</table>
</body>
</html>

拓展阅读

PHP导出带样式的Excel

PHP header 的几种用法

Smarty 模板函数


Thanks ~

欢迎大家进行讨论 (留言、私信均可)~

相关文章

  • PHP导出报表(案例)

    效果 需求 为了实现报表效果,自己杜撰的需求。 主要是思路,思路通了实现其他效果也OK。 统计每个人在一年中每一天...

  • csv生僻字处理和格式控制

    转自:Php导入导出csv文件时的生僻字处理和格式控制 - 班登 - 博客 应用场景 Web应用中导入导出报表是一...

  • 如何优雅的导出 Excel

    前言 公司项目最近有一个需要:报表导出。整个系统下来,起码超过一百张报表需要导出。这个时候如何优雅的实现报表导出,...

  • ES6模块系统备忘

    案例一:基础使用 案例二:集中式导出 案例三:换名导出,换名导入 案例五:默认导出导入

  • 工作中遇到的问题

    1.报表导出过慢的问题:在一次报表导出数据的过程中,随着业务量的增加,导出一个报表的时间过长,达到了2至3s钟,业...

  • Kendoui之grid保存为Excel

    在制作报表时常会遇到的需求是报表的导出。将报表导出为一个Excel格式更便于浏览、维护及打印。同时Grid也提供了...

  • 002.关于报表类需求分析

    1.报表导出字段 避免导出冗余字段 2.报表导出格式 一般为csv格式,xls格式有数量行的限制 但注意csv的格...

  • PHP excl导出类

    PHP excl导出类

  • JAVA使用POI中XSSF方法导出excel

    今天分享的是POI方法导出excel,这两个月时间我的大部分工作都是导出报表,今天就给大家分享excel报表的导出...

  • springboot使用poi进行报表导出小demo

    1.添加依赖 2.案例描述:从数据库student1表中查询出来的数据进行报表导出(前台页面使用a标签进行链接就可...

网友评论

  • 新亮笔记:作者:PHP后端开发者

    免费提供技术咨询服务(自己懂的知识)。

    关注微信公众号,留言即可,看到留言后会及时回复。

    微信名称:IT小圈儿,微信号:ToFeelings,欢迎一起学习。

本文标题:PHP导出报表(案例)

本文链接:https://www.haomeiwen.com/subject/vlqpbttx.html