如何通过PHP将excel的数据导入MySQL中

如何通过PHP将excel的数据导入MySQL中,第1张

在开发PHP程序时,很多时候我们会有将数据批量导入数据库的需求,如学生信息批量添加到数据库中,而事先用excel编排好,对excel实行 *** 作,便是我们比较常用的选择方式。

在对excel的 *** 作中,phpExcelReade便是很多人的共同选择。在具体实现中,我们可以以文件上传方式将excel文件上传到服务器中的某个位置,通过以下 *** 作将excel中的数据导入到数据库后,在将上传的文件删除即可。

代码如下:

$dir=dirname(__FILE__)                       //获取当前脚本的绝对路径

$dir=str_replace(“//”,”/”,$dir).”/”

$filename=’uploadFile.xls' //可以定义一个上传后的文件名称

$result=move_uploaded_file($_FILES[‘upload’][‘tmp_name’],$dir.$filename)//假如上传到当前目录下

if($result)  //如果上传文件成功,就执行导入excel *** 作

{

require_once ‘phpExcelReader/Excel/reader.php'

$data = new Spreadsheet_Excel_Reader()

$data->setOutputEncoding(‘utf-8′)//设置在页面中输出的编码方式,而不是utf8

//该方法会自动判断上传的文件格式,不符合要求会显示错误提示信息(错误提示信息在该方法内部)。

$data->read(“$filename”)  //读取上传到当前目录下名叫$filename的文件

error_reporting(E_ALL ^ E_NOTICE)

//如果excel表带标题,则从$i=2开始,去掉excel表中的标题部分(要将$i<=改为$i<否则会插入一条多余的空数据)

for ($i = 2 $i < $data->sheets[0][‘numRows’] $i++)

{

$sql = “INSERT INTO user (stuid,class,name,sex,classNum,tel,addr,remark) VALUES(‘”.

$data->sheets[0][‘cells’][$i][1].”‘,'”.    //学号

$data->sheets[0][‘cells’][$i][2].”‘,'”.    //班级

$data->sheets[0][‘cells’][$i][3].”‘,'”.    //姓名

$data->sheets[0][‘cells’][$i][4].”‘,'”.    //性别

$data->sheets[0][‘cells’][$i][5].”‘,'”.    //班内序号

$data->sheets[0][‘cells’][$i][6].”‘,'”.    //联系电话

$data->sheets[0][‘cells’][$i][7].”‘,'”.    //联系地址

$data->sheets[0][‘cells’][$i][8].”‘)”     //附注

$db->query($sql)

$insert_info.= ” $sql</br>/n”          //可以用来显示数据插入的信息

}

$totalNums=$data->sheets[0][‘numRows’]-2//求出导入的总数据条数(这里是减去2,才会得到去除标题后的总数据)

//echo “导入成功!”

unlink(“$filename”)                             //删除上传的excel文件

}

else

{

$errmsg=”上传失败”

}

第一步:建立数据库和数据表(按照自己的Excel数据设立字段)。

[sql] view plain copy print?

CREATE DATABASE php_excel

USE php_excel

CREATE TABLE IF NOT EXISTS php_excel(

id int(20) NOT NULL AUTO_INCREMENT PRIMARY KEY,

gid varchar(20) NOT NULL,

stu_no varchar(20) NOT NULL,

name varchar(45) NOT NULL,

age int(4) NOT NULL

)ENGINE=MyISAM DEFAULT CHARSET=utf8

第二步:前台index.php文件。

[html] view plain copy print?

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8" />

<title>phpexcel导入excel数据到MYSQL数据库</title>

</head>

<body>

<form name="frm1" action="insertdb.php" method="post" enctype="multipart/form-data">

<input name="filename" type="file" />

<input name="submit" type="submit" value="import" />

</form>

</body>

</html>

第三步:向数据库插入数据的insertdb.php文件。

[php] view plain copy print?

session_start()

header("Content-type:text/htmlcharset:utf-8")

//全局变量

$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

}

}

require("./conn.php") //连接mysql数据库

//调用phpexcel类库

require_once 'PHPExcel.php'

require_once 'PHPExcel\IOFactory.php'

require_once 'PHPExcel\Reader\Excel5.php'

$objReader = PHPExcel_IOFactory::createReader('Excel5')//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 php_excel(gid,stu_no,name,age) values ($strs[0],'$strs[1]','$strs[2]',$strs[3])"

echo $sql."<br/>"

mysql_query("set names utf8")

$result=mysql_query($sql) or die("执行错误")

$insert_num=mysql_affected_rows()

if($insert_num>0){

$succ_result+=1

}else{

$error_result+=1

}

}

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

echo "插入失败".$error_result."条数据!!!"

其中conn.php代码如下:

[php] view plain copy print?

$mysql=mysql_connect("localhost","root","") or die("数据库连接失败!")

mysql_select_db("php_excel",$mysql)

mysql_query("set names utf8")

我的导入效果如下:

至此,从Excel文件读取数据批量导入到Mysql数据库完成。

我看了下你的代码,发现html部分跟php部分貌似脱节了.按照目前的代码,无论你在html界面提交什么附件,php程序都是读取处理跟它(这个.php文件)同一目录的"date.xls"文件.现在报这个错误很大可能是没有.php文件所在目录没有"date.xls"这个文件.

要实现你的功能,至少要将"date.xls"文件改为你上传的文件.

试试把

$data->read('date.xls')

改成

$data->read($_FILE['file']['tmp_name'])


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9892109.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存