excel表格生成与导入

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

1、生成excel表格

<?php
header("content-type:text/html;charset=utf-8");
$dsn = "mysql:dbname=news;host=127.0.0.1";
$user = "root";
$pwd = "";
$pdo = new PDO($dsn,$user,$pwd);
//$sql = "select id,name.content,descs from brand";
$res = $pdo->query("select id,name,content,descs from brand");
$arr = $res->fetchAll(PDO::FETCH_ASSOC);
//$res = $pdo->exec("select id,name,content,descs from brand");
//$data = $res->execute();
//$arr = $res->fetchAll(PDO::FETCH_ASSOC);
//print_r($arr);die;
//引入类文件
require_once './Classes/PHPExcel.php';
require_once './Classes/PHPExcel/IOFactory.php';
require_once './Classes/PHPExcel/Reader/Excel5.php';

//创建新的PHPExcel对象
$objPHPExcel = new PHPExcel();
$objProps = $objPHPExcel->getProperties();
//设置表头
//ord():ord() 函数返回字符串第一个字符的 ASCII 值。 语法 ord(string) 参数描述 string 必需。要从中获得 ASCII 值的字符串
$i = 0;
foreach($arr as $k=>$v){
    //print_r($v);die;
    if($i<1){
        $obj=array_keys($v);//array_keys() 函数返回包含数组中所有键名的一个新数组
        //print_r($obj);die;
        $key = ord("A");
        //print_r($key);die;
        foreach($obj as $ke=>$va){
            //print_r($va);die;
           $colum = chr($key);//输出excel表格中的行的(ABCD....),如果显示B,则循环$key+1,
           //print_r($colum);//获取excel表格中的行的ABCD
           $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $va);//setCellValue()单元格赋值;
           $key+=1;
        }
    }
    $i++;
}

    $column = 2;
    $objActSheet = $objPHPExcel->getActiveSheet();
    //print_r($objActSheet);die;
    foreach($arr as $key => $rows){ //行写入
        //print_r($rows);die;
        $span = ord("A");
        foreach($rows as $keyName=>$value){// 列写入
            //print_r($value);die;//获取本条数据的id
            $h = chr($span);
            //print_r($h);die;
            $objActSheet->setCellValue($h.$column, $value);
            $span++;
        }
        $column++;
    }

    //生成excel文件
    //$fileName="excel.xls";
     $fileName = iconv("utf-8", "gb2312", "shengcheng.xls");
    //重命名表
    $objPHPExcel->getActiveSheet()->setTitle('Simple');
    //设置活动单指数到第一个表,所以Excel打开这是第一个表
    $objPHPExcel->setActiveSheetIndex(0);
    //将输出重定向到一个客户端web浏览器(Excel2007)
      header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
      header("Content-Disposition: attachment; filename=\"$fileName\"");
      header('Cache-Control: max-age=0');
      $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
      $objWriter->save('php://output'); //文件通过浏览器下载
      exit;
?>


2、将生成的execl表格的数据入库

2.1、首先写一个form表单  
<META NAME="" CONTENT="" charset="utf-8">
<form name="frm1" enctype="multipart/form-data" action="daoru.php" method="post">
   <input name="filename" type="file" /><input name="submit" type="submit" value="上传" />
</form>

2.2、通过form 表单跳到指定的目录

<?php
header("content-type:text/html;charset=utf-8");

session_start();
//全局变量
$succ_result=0;
$error_result=0;
$file=$_FILES['filename'];
$max_size="2000000"; //最大文件限制(单位:byte)
$fname=$file['name'];
$ftype=strtolower(substr(strrchr($fname,'.'),1));
 //文件格式
 $uploadfile=$file['tmp_name'];
 if($_SERVER['REQUEST_METHOD']=='POST'){
     if(is_uploaded_file($uploadfile)){
          if($file['size']>$max_size){
         echo "Import file is too large"; 
         exit;
         }
          if($ftype!='xls'){
         echo "Import file type is error";
          exit;   
         }
     }else{
     echo "The file is not empty!";
      exit; 
     } 
 }
  //连接mysql数据库
$dsn = "mysql:dbname=news;host=127.0.0.1";
$user = "root";
$pwd = "";
$pdo = new PDO($dsn,$user,$pwd);



//调用phpexcel类库
/*
require_once 'phpexcel.php'; 
require_once 'PHPExcel\IOFactory.php';
require_once 'PHPExcel\Reader\Excel5.php';
*/
//引入类文件
require_once './Classes/PHPExcel.php';
require_once './Classes/PHPExcel/IOFactory.php';
require_once './Classes/PHPExcel/Reader/Excel5.php';



$objReader = PHPExcel_IOFactory::createReader('Excel2007');//use excel2007 for 2007 format 
$objPHPExcel = $objReader->load($uploadfile); 
$sheet = $objPHPExcel->getSheet(0); 
$highestRow = $sheet->getHighestRow(); // 取得总行数 
$highestColumn = $sheet->getHighestColumn(); // 取得总列数
  $arr_result=array();
  $strs=array();

for($j=2;$j<=$highestRow;$j++)
 { 
    unset($arr_result);
    unset($strs);
 for($k='A';$k<= $highestColumn;$k++)
    { 
     //读取单元格
  @$arr_result  .= $objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue().',';
    }
 $strs=explode(",",$arr_result);
 $sql="insert into brand(id,name,content,descs) values ($strs[0],'$strs[1]','$strs[2]','$strs[3]')";
 echo $sql."<br/>"; 
// mysql_query("set names utf8");
 $result=$pdo->exec($sql) or die("执行错误");

// $insert_num=mysql_affected_rows();
  if($result>0){
        $succ_result+=1;
    }else{
        $error_result+=1;
   }

}

echo "插入成功".$succ_result."条数据!!!<br>";
echo "插入失败".$error_result."条数据!!!";

?>



      本文转自噼里啪啦啦 51CTO博客,原文链接:http://blog.51cto.com/pilipala/1639873,如需转载请自行联系原作者







相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2月前
|
Java API Apache
Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
【10月更文挑战第29天】Java编程如何读取Word文档里的Excel表格,并在保存文本内容时保留表格的样式?
177 5
|
23天前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
2月前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
40 1
|
2月前
|
SQL 数据可视化 数据挖掘
想让Excel表格设计更美观?试试这几款好用工具!
Excel表格设计在项目管理和数据分析中至关重要。本文推荐四款辅助工具:板栗看板、Excel自动图表助手、Think-Cell Chart 和 Power BI,分别在任务管理、图表生成、数据可视化等方面表现突出,帮助你设计出更专业、美观的表格。
103 2
|
3月前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
176 6
|
4月前
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
|
3月前
|
前端开发 JavaScript API
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
前端基于XLSX实现数据导出到Excel表格,以及提示“文件已经被损坏,无法打开”的解决方法
275 0
|
3月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
137 0
|
5月前
|
人工智能 BI
用ChatGPT做excel表格真香!只需动嘴提要求和复制粘贴
用ChatGPT做excel表格真香!只需动嘴提要求和复制粘贴
214 0
|
6月前
|
数据可视化 数据管理 定位技术
如何将QGIS中的属性表与Excel表格关联?
作为UE开发人员,经常会使用到QGIS进行数据管理编辑。QGIS与Excel之间数据并不完全兼容,而UE开发过程中大部分的前期数据都储存在Eecel里。为了将Excel数据写入QGIS属性表实现数据可视化,我们内部总结了一个最快捷的方法

热门文章

最新文章