在写php时遇到的PHPExcel相关问题记录(含excel与mysql交互代码)

2017-6-26

错误一:

错误描述:在将日期插入到数据库时失败,为4开头的5位数字(这个数字代表1900-1-1到这个日期的天数),所以显示出来的是没有经过格式化的日期,在数据库中设置类型为DATE,则该日期插入不成功,显示0000-00-00

改错步骤:将日期单独拿出判断,格式化之后存到数组,$valueStr变量根据数组值传到数据库,数组中已经是格式化后的日期了

 if($col){//将日期列单独拿出来判断,做格式化操作,再存到数组
              $ExamPaper_arr[$i][$col] = gmdate("Y-m-d", PHPExcel_Shared_Date::ExcelToPHP($sheet->getCellByColumnAndRow($col,$row)->getValue())); //格式化日期
        }
        else{//其他操作不用管
        $ExamPaper_arr[$i][$col]=$sheet->getCellByColumnAndRow($col,$row)->getValue();//将每一个单元格存为二维数组,行对应excel的行,列对应列
        }       
    }


顺便把excel与数据库交互的代码也放上好了,仅供参考,这里只写excel2007(不代表只支持2007,2007往上的都可以,如果是其他可以excel5写个判断就可以了)

<?php  
include('mysql.php');//连接数据库语句操作
header("content-Type: text/html; charset=UTF-8");//编码
error_reporting(E_ALL^ E_NOTICE);
require '/Classes/PHPExcel/IOFactory.php';
require '/Classes/PHPExcel.php';//操作excel语句
require '/Classes/PHPExcel/Reader/Excel2007.php'; //这句关键

$excel_file = $uploadfile;//$uploadfile这里写自己的excel表名,实际用这代码操作只需要改表名就可以了是,注意数据库字段和excel标题行那里是一样的,因为我这里用字符串设置好格式存好了它的标题行直接在数据库插入语句那里用的这个字符串变量
//$excel_file = 'excel2016.xlsx';//要操作的表名
$PHPExcel = new PHPExcel();//新建PHPExcel类的对象
$PHPReader = new PHPExcel_Reader_Excel2007(); //还有这句也是关键
//$PHPExcel = $PHPReader->load($excel_file);//加载excel数据表,如果数据表太大容易造成http崩溃
$PHPExcel = PHPExcel_IOFactory::load($excel_file);//改成这种方式就可以了
$sheet = $PHPExcel->getActiveSheet();//当前活动的工作表
//获取行和列
$allCol=PHPExcel_Cell::columnIndexFromString($sheet->getHighestColumn());
$allRow=$sheet->getHighestRow();

/*---------------------------------------------------分界线-----------------------------------------------------------------------------*/    
//$StringTest='`姓名`,`性别`,`专业`,`年级`,`年龄`';//把字段改为字符串,有数据库语句时调用,这里是自己在本地的虚拟excel表
//参考上一句注释优化了一下,因字段太多想简化所以这个循坏用来保存表头,以字符串形式存进$StringTest变量中
$StringTest='(';    //前后需要括号
    for ($col=0;$col<$allCol;$col++)//内循环为列
    {
        $ExamPaper_arr[0][$col]=$sheet->getCellByColumnAndRow($col,1)->getValue();//将每一个单元格存为二维数组,行对应excel的行,列对应列
        //echo $ExamPaper_arr[$i][$col];
            $StringTest.="`".$ExamPaper_arr[0][$col]."`";
            if(($col+1)<$allCol)//最后一个不加逗号
                $StringTest .=',';                
            else $StringTest .=')';//结束括号
    }
/*---------------------------------------------------分界线-----------------------------------------------------------------------------*/    
//第二个循环,双重循环遍历剩余数据行。定义字符串型变量$valueStr保存剩余字段
for($row=2,$i=0; $row<=$allRow;$row++,$i++)//外循坏为行,为方便i变量控制数组下标从0开始保存
{
    $valueStr='(';//两边括号固定写法
    for ($col=0;$col<$allCol;$col++)//内循环为列
    {
        if($col==xx){//将日期列单独拿出来判断,做格式化操作,再存到数组
              $ExamPaper_arr[$i][$col] = gmdate("Y-m-d", PHPExcel_Shared_Date::ExcelToPHP($sheet->getCellByColumnAndRow($col,$row)->getValue()));  //格式化日期
        }
        else{
        $ExamPaper_arr[$i][$col]=$sheet->getCellByColumnAndRow($col,$row)->getValue();//将每一个单元格存为二维数组,行对应excel的行,列对应列
        }
        //echo $ExamPaper_arr[$i][$col];
        $valueStr .="'".$ExamPaper_arr[$i][$col]."'";//两边须加单引号,存值时固定写法
        
            if(($col+1)<$allCol)//最后一个不加逗号
                $valueStr .=',';
                echo $ExamPaper_arr[$i][$col];
                echo ",";
        
    }
     //$valueStr .="('".$ExamPaper_arr[$i][0]."','".$ExamPaper_arr[$i][1]."','".$ExamPaper_arr[$i][2]."','".$ExamPaper_arr[$i][3]."','".$ExamPaper_arr[$i][4]."'),";
    echo "<br/>";
    $valueStr.=')';//结束括号
    //echo $StringTest;
    $sql1 = "insert into cbqd $StringTest values $valueStr";//调用了最上方定义的字符串$StringTest,存的是字段
    mysql_query($sql1);
    var_dump(mysql_error());//打印数据库语句错误集
            //echo $i;
}
?>


第一次发帖,就是记录一下学习中遇到的问题嘻嘻,因为不会框架所以代码很乱七八糟的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值