php3.2.3导入一个大数据量的excle到数据库中出现的问题。

2024-04-30 07:18

本文主要是介绍php3.2.3导入一个大数据量的excle到数据库中出现的问题。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 首先把excle导入到数据库中,分三步走,第一excle上传服务器,第二服务器解析数据,第三插入数据库。

在thinkphp中有封装好的upload() 和phpexcle,看起来问题不大,实际上问题一大堆,首先上传文件到指定目录,需要注意的是文件后缀,文件大小,文件名,文件路径等。

上传到服务器之后运用phpexcle打开文件,将每一行的数据插入到数据库之中去,看起来问题不大,由于列数过于庞大,26个字母不能满足A到HD,写的程序只能解析A到H即8个属性,远远满足不了导入的需求,百度了一下也没有找到什么好的解决方法,最后写了两个函数来定义循环的长度,A对应1,HD对应212,循环通过数字,地址通过字母,解决了之一问题。

function changenum($value)
        {
          $num=array('0','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');
          unset($num[0]);
          $num=array_flip($num);
          $value='HD';
          $str0=substr("$value", 0, 1);
          $str1=substr("$value", 1, 1);
          
          if($str1==null){$str1=0;}
          $result=$num[$str0]*26+$num[$str1];
         
         
          return $result;
        }
        function returnnum($value){
          $num=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');
          unset($num[0]);
         
         
          $time=floor($value/26);
        
         
          $first=$num[$time];
        
          $time1=$value-$time*26;
      
        
          $second=$num[$time1];
        
          if($first=="!"){$first=null;}
          if($second=="!"){$second=null;}
          $result=$first.$second;
         
       return $result;

}
核心代码
$currentSheet=$PHPExcel->getSheet(0);
  //获取总列数
  $allColumn=$currentSheet->getHighestColumn();
  $allColumn=changenum($allColumn);


 
  //获取总行数
  $allRow=$currentSheet->getHighestRow();

//循环获取表中的数据,$currentRow表示当前行,从哪行开始读取数据,索引值从0开始
  for($currentRow=1;$currentRow<=$allRow;$currentRow++){
  //从哪列开始,A表示第一列
  for($currentColumn=1;$currentColumn<=$allColumn;$currentColumn++){
  //数据坐标
 
  $colum=returnnum($currentColumn);
 

$address=$colum.$currentRow;
 
  //读取到的数据,保存到数组$arr中
 
  $arr[$currentRow][$currentColumn]=$currentSheet->getCell($address)->getValue();
 
     }

}

这篇关于php3.2.3导入一个大数据量的excle到数据库中出现的问题。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/948218

相关文章

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Springboot3统一返回类设计全过程(从问题到实现)

《Springboot3统一返回类设计全过程(从问题到实现)》文章介绍了如何在SpringBoot3中设计一个统一返回类,以实现前后端接口返回格式的一致性,该类包含状态码、描述信息、业务数据和时间戳,... 目录Spring Boot 3 统一返回类设计:从问题到实现一、核心需求:统一返回类要解决什么问题?

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

idea粘贴空格时显示NBSP的问题及解决方案

《idea粘贴空格时显示NBSP的问题及解决方案》在IDEA中粘贴代码时出现大量空格占位符NBSP,可以通过取消勾选AdvancedSettings中的相应选项来解决... 目录1、背景介绍2、解决办法3、处理完成总结1、背景介绍python在idehttp://www.chinasem.cna粘贴代码,出

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA

SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)

《SpringBoot整合Kafka启动失败的常见错误问题总结(推荐)》本文总结了SpringBoot项目整合Kafka启动失败的常见错误,包括Kafka服务器连接问题、序列化配置错误、依赖配置问题、... 目录一、Kafka服务器连接问题1. Kafka服务器无法连接2. 开发环境与生产环境网络不通二、序

SpringSecurity中的跨域问题处理方案

《SpringSecurity中的跨域问题处理方案》本文介绍了跨域资源共享(CORS)技术在JavaEE开发中的应用,详细讲解了CORS的工作原理,包括简单请求和非简单请求的处理方式,本文结合实例代码... 目录1.什么是CORS2.简单请求3.非简单请求4.Spring跨域解决方案4.1.@CrossOr

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

使用Python实现在PDF中添加、导入、复制、移动与删除页面

《使用Python实现在PDF中添加、导入、复制、移动与删除页面》在日常办公和自动化任务中,我们经常需要对PDF文件进行页面级的编辑,使用Python,你可以轻松实现这些操作,而无需依赖AdobeAc... 目录1. 向 PDF 添加空白页2. 从另一个 PDF 导入页面3. 删除 PDF 中的页面4. 在