thinkPHP3.2使用phpexcel导入文件到数据库

thinkPHP3.2使用phpexcel导入文件到数据库,第1张

这是我写过的,绝对能用,不行你再找我!!

<?php

if($_POST[sub]){

$uptypes=array('application/vnd.ms-excel','application/octet-stream')

$max_file_szie=20*pow(2,20) //上传的文件小于20MB

$destination_folder='../conn/'//上传文件保存路径

if($_SERVER['REQUEST_METHOD']=='POST'){

if(!is_uploaded_file($_FILES['upfile']['tmp_name'])){

exit("<script>alert('文件不存在!')history.back()</script>")

}

if($max_file_szie<$_FILES['碰谨芦upfile']['size']){

exit("<script>alert('文件太大了!')history.back()</script>")

}

if(!in_array($_FILES['upfile']['type'],$uptypes)){

echo '文件类型不符合!'.$_FILES['upfile']['type']

exit("<script>alert('文件类型不符合!')history.back()</script>")

}

if(!file_exists($destination_folder)){

mkdir($destination_folder)

}

$filename=$_FILES['upfile']['tmp_name']

$image_size=getimagesize($filename)

$pinfo=pathinfo($_FILES['upfile']['name'])//文件路径信息

$ftype=$pinfo['extension']//旧文件后缀名

$destination = $destination_folder.$_FILES['upfile']['name']//新文件名称

if(file_exists($destination)&&$voerwrie !=true){

exit("<script>alert('同名文件已经存在了!')history.back()</script>")

}

//把上传的文件从临时文件夹移动到指定目录

if(!move_uploaded_file($filename,$destination)){

exit("<script>alert('移动文件出错了!')history.back()</script>")

}

$pinfo=pathinfo($destination)

$fname=$pinfo[basename]

$tpfile=$destination//上传文件名

//-----------上传成功,导入数据star-----

$dataf=$tpfile

if(!file_exists($dataf))

{

exit("文件不存在") //文件不存在

}

$file = fopen("$dataf",'r')

while ($d = fgetcsv($file)) {//每次读取CSV里面笑带的晌咐一行内容

//print_r($d)//此为一个数组,要获得每一个数据,访问数组下标即可

$type="`uid`='$d[0]' &&name='$d[1]'"

$dsql=dbst($tableqz.message2,$type)

if(!$dsql){

$uid=trim($d[0])//编号

$name=trim($d[1])//客户名称

$type="(`uid`, `username`, `password`) VALUES (NULL, '$uid', '$name')"

dbin(hh_members,$type)

}

}

fclose($file)

unlink("$dataf")

}

//---上传end

exit("<script>alert('成功导入了所有数据!')history.back()</script>")

}

?>

第一步:建立数据库和数据表(早核按照自己的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数据库完成。

个改世人感觉 PHPExcel还是很好用的,首先到官方网站http://phpexcel.codeplex.com/下载最近版本的PHPExcel,解压后会发现里面有class、Documentation、Tests三个文件夹和三个txt的日志文件,主要用到的是Class文件,而Tests主要是一些demo示例

下面来介绍一下PHPExcel的悉携简单用法,这里是与数据库连接的:

首先,要包含PHPExcel.PHP

require_once 'Classes/PHPExcel.php' //路径根据自己实际项目的路径进行设置

$objPHPExcel = new PHPExcel() //创建PHPExcel实例

//下面是对MySQL数据库的连接

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

mysql_select_db("image",$conn) //连接数据库

mysql_query("set names 'GBK'") //转换字符编码

$sql = mysql_query("select * from test") //查询sql语句

/*--------------设置表头信息------------------*/

$objPHPExcel->setActiveSheetIndex(0)

->setCellValue('A1', 'ID编号')

->setCellValue('B1', '月份')

->setCellValue('C1', '产品一')

->setCellValue('D1', '产品二')

->setCellValue('E1', '产品三')

/*--------------开始从数据库提取信息插入Excel表中------------------*/

$i=2 //定义一个i变量,目的是在循环输出数据是控制行数

while($rs=mysql_fetch_array($sql)){

$rm = iconv("GB2312","UTF-8",$rs[1])//对字符进行编码将数据库里GB2312的中文字符转换成UTF-8格式

$objPHPExcel->setActiveSheetIndex(0)

->setCellValue("A".$i, $rs[0])

->setCellValue("B".$i, $rm)

->setCellValue("C".$i, $rs[2])

->setCellValue("D".$i, $rs[3])

->setCellValue("E".$i, $rs[4])

$i++

}

/*--------------下面是设置其他信息------------------*/

$objPHPExcel->getActiveSheet()->setTitle('Example1') //设置sheet的名称

$objPHPExcel->setActiveSheetIndex(0) //设置sheet的起始位置

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5') //通过PHPExcel_IOFactory的写函数将上面数据写出来

$objWriter->save(str_replace('.php', '.xls', __FILE__))//设置以什么格式保存,及保存位置

至此,一个完整的将mysql数据库里的信息用PHP导出Excel实例做完,可能在运行的时候会发生一些问题,如中文乱码,核陆肢表头可能显示不出来,这是因为文件编码格式的原因,将文件编码设置成UTF-8就行了,在此我就不做太多解释了。


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

原文地址: http://outofmemory.cn/tougao/12283352.html

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

发表评论

登录后才能评论

评论列表(0条)

保存