雅荷心语博客
雅荷心语
心之所向便是光
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 关注本站
    • 微信
    • 微博
    • 腾讯微博
    • Twitter
    • Facebook
    • RSS订阅
Hi, 请登录     我要注册     找回密码

使用PHPExcel生成表格数据并下载

2018-01-29 分类:后端之路 阅读(2840) 评论(0)

首先我们使用composer安装 PHPExcel

composer require phpoffice/phpexcel

安装完成后,

1
2
3
4
5
6
7
8
9
10
$objPHPExcel = new \PHPExcel();
        $objPHPExcel
            ->getProperties()  //获得文件属性对象,给下文提供设置资源
            ->setCreator("天明")             //设置文件的创建者
            ->setLastModifiedBy("天明")       //设置最后修改者
            ->setTitle("天明的表格")    //设置标题
            ->setSubject("Office2007 XLSX Test Document" )  //设置主题
            ->setDescription("") //设置备注
            ->setKeywords( "office 2007 openxmlphp") //设置标记
            ->setCategory( "Test resultfile");     //设置类别

基本操作

1
2
3
4
5
6
7
//        $objPHPExcel->setActiveSheetIndex(0)  //设置第一个内置表(一个xls文件里可以有多个表)为活动的
//        ->setCellValue( 'A1', 'Hello' )       //给表的单元格设置数据
//        ->setCellValue( 'B2', 'world!' )      //数据格式可以为字符串
//        ->setCellValue( 'C1',12)            //数字型
//        ->setCellValue( 'D2',12)            //
//        ->setCellValue( 'D3', true )        //布尔型
//        ->setCellValue( 'D4', '=SUM(C1:D2)' );//公式

记录一个实例:

首先查询我的数据库字段注释!

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
    /**
     * 获取数据库字段注释
     * @param string $table_name 数据表名称(必须,不含前缀)
     * @param string $field 字段名称(默认获取全部字段,单个字段请输入字段名称)
     * @param string $table_schema 数据库名称(可选)
     * @return string
     */
    public static function tableDesc($table_name = '', $field = true, $table_schema = ''){
        // 接收参数
        $database = config('database');
        $table_schema = empty($table_schema) ? $database['database'] : $table_schema;
        $table_name = $database['prefix'] . $table_name;
        // 缓存名称
        $fieldName = $field === true ? 'allField' : $field;
        $cacheKeyName = 'db_' . $table_schema . '_' . $table_name . '_' . $fieldName;
        // 处理参数
        $param = [
            $table_name,
            $table_schema
        ];
        // 字段
        $columeName = '';
        if($field !== true){
            $param[] = $field;
            $columeName = "AND COLUMN_NAME = ?";
        }
        // 查询结果
        $result = Db :: query("SELECT COLUMN_NAME as field,column_comment as comment FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = ? AND table_schema = ? $columeName", $param);
        if(empty($result) && $field !== true){
            return $table_name . '表' . $field . '字段不存在';
        }
        return count($result) == 1 ? reset($data) : $result;
    }

然后把字段注释写入Excel并且下载!

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
$objPHPExcel = new \PHPExcel();
        $objPHPExcel
            ->getProperties()  //获得文件属性对象,给下文提供设置资源
            ->setCreator("天明")             //设置文件的创建者
            ->setLastModifiedBy("天明")       //设置最后修改者
            ->setTitle("天明的表格")    //设置标题
            ->setSubject("Office2007 XLSX Test Document" )  //设置主题
            ->setDescription("") //设置备注
            ->setKeywords( "office 2007 openxmlphp") //设置标记
            ->setCategory( "Test resultfile");     //设置类别
 
        $headerData = self::tableDesc('data');
        $numIndex = 1;
        foreach ($headerData as $k=> $v){
            $numIndex++;
            $objPHPExcel->setActiveSheetIndex(0)
            ->setCellValue( 'A'.$numIndex, $v['comment']); //.'('.$v['field'].')'
        }
        $objActSheet =$objPHPExcel->getActiveSheet();
        $objActSheet->getColumnDimension('A')->setAutoSize(true);
        $objActSheet->setTitle('第一页');
        header('Content-Type:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
        header('Content-Disposition:attachment;filename="01simple.xlsx"');
        header('Cache-Control:max-age=0');
        $objWriter = \PHPExcel_IOFactory:: createWriter($objPHPExcel, 'Excel2007');
        $objWriter->save( 'php://output');
        exit;

 

喜欢 (1) 赏 讨厌 (0)
分享到:更多 ()
标签:常用软件思路分析

相关推荐

  • 获取上传文件实时进度条的尝试
  • 记录几个常用的HTML空格占位符
  • vue 官方推荐Nuxt.js 服务端渲染尝试!
  • Electron 生成的桌面应用破解方法
  • centos 升级git到最新版
  • 深夜来配置一个新项目,Laravel与Vue+ElementUI组合
  • PHP实时监控文件夹内容变动并且复制内容到指定的目录
  • node 模块镜像备注
关于我

小天明 北京·朝阳 前端搬砖工程师

碎碎念):(来自公众号)

热门文章

  • 踩坑记录——iphone上safari开启隐身模式时localStorage变为只读-雅荷心语博客踩坑记录——iphone上safari开启隐身模式时localStorage变为只读2017-02-21评论(4)
  • 程序员是怎样一群人-雅荷心语博客程序员是怎样一群人2015-12-08评论(3)
  • 百度你个大毒瘤 - 吐糟博客这几天打不开事情-雅荷心语博客百度你个大毒瘤 – 吐糟博客这几天打不开事情2015-12-28评论(2)
  • PHP 非对称加密 openssl 加密及解密方法-雅荷心语博客PHP 非对称加密 openssl 加密及解密方法2016-05-17评论(2)
  • PHPStorm10 下载安装破解汉化-雅荷心语博客PHPStorm10 下载安装破解汉化2015-12-15评论(2)
2025年7月
一 二 三 四 五 六 日
« 六    
 123456
78910111213
14151617181920
21222324252627
28293031  

最新评论

  • 前端小武 8年前 (2017-04-06)说:
    我看到了layer
  • 丁艳平 8年前 (2017-03-03)说:
  • Dawn 9年前 (2016-09-16)说:
    call_user_func_array最后的例子是错哦,你用bc方法去调用类里 另外一个方法就知道问题所在了。情况1.调用非静态方法 第一个参数应该传[类的实例,调用方法] (既然有类实例了直接-&
  • Dawn 9年前 (2016-06-21)说:
    tp框架设置了全局捕获异常的,这也没什么。坑的是 他捕获了异常。然后全部返回404。。。不知道的 还以为自己网站被删除了
  • Dawn 9年前 (2016-05-17)说:
    构造函数里的判断 用异常机制可能更好一些

其他类型

  • 芊云全景
  • 配音兔AI配音神器

博客类型

  • 芊云全景
  • 配音兔AI配音神器

左邻右舍

  • 易水寒
  • 楼教主
  • 芊云全景
  • 贤心
  • 配音兔AI配音神器

雅荷心语博客 -心之所向便是光

联系我们关于我们

© 2025 雅荷心语博客   网站地图