PHP导出Excel方法很多,网上也有很多成熟的类,现在用最简单的方法导出一个Excel, 输出一个Table,然后用header 类型改为Excel就可以.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
| <?php
includer_once("config.php");
$sql="select * from user";
$result=mysql_query($sql);
$data_array=mysql_fetch_array($result);
$keynames=array("orderTrade"=>"订单号","orderRecName"=>"收货人姓名","orderCount"=>"数量","orderPhone"=>"电话","orderRecMail"=>"Email","orderRecAddress"=>"地址","orderRecZip"=>"邮编","receiving"=>"收货时间");
function down_xls($data_array,$keynames,$filename) {
//组合表头行,以制表符\t分隔,并转码为gb18030
$title = implode("\t", array_values($keynames));
$title = iconv("UTF-8","GB18030", $title);
$result[] = $title;
//组合表体行
foreach ($data_array as $data){
//按行组合数据体
$a1 = array();
foreach ($keynames as $k => $v){
if ($k == "endtime"){
$data[$k] = date("Y-m-d H:i", $data[$k]);
}
//utf8转码到gb18030,为了windows正常显示
$a1[] = iconv("UTF-8","GB18030", preg_replace("/[\t]+/"," ",$data[$k]));
}
//以制表符分隔每列
$result[] = implode("\t", $a1);
}
//为了windows下正常显示,以\r\n为换行符,分隔数据字符串
$result = implode("\r\n", $result);
header("Content-type: text/html; charset=GB18030");
header("Content-Disposition: attachment; filename=\"".$filename.".xls\"");
exit($result);
}
down_xls($data_array,$keynames,"dataxls");
?> |
前面写过一篇PHP读取EXCEL插入Mysql数据库中,应用phpExcelReader导入, 这次做毕业设计时用的ThinkPHP,有个上传学生信息(excel)插入数据库的功能,其实原理一样,先是上传,然后读取内容,然后根据phpExcelReader的read读取各sheet值然后插入数据库。其代码为:
import.html
1
2
3
4
5
6
7
| <form method="post" action="__URL__/import" name="form1" enctype="multipart/form-data">
<table cellspacing="0" cellpadding="0" border="1">
<tr>
<td ><input type="file" name="myfile" /> <input type="submit" class="mybutton" name="import" value="导入" ></td>
</tr>
</table>
</form> |
StudentsAction.class.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
| class StudentsAction extends Action
{
public function import()
{
header("Content-Type:text/html; charset=utf-8");
Vendor('Excel.reader'); // 加载reader类。
if(!$this->isPost())
{
$this->display();
}
else
{
if($_FILES['myfile']['name']!='')
{
$tmp_file=$_FILES['myfile']['tmp_name'];
$file_types=explode(".",$_FILES['myfile']['name']);
$file_type=$file_types[count($file_types)-1];
if(strtolower($file_type)!="xls"){
// echo "<span style=\"color:red;line-height: 25px;\">格式错误 <a href=\"#\" onclick=history.go(-1);>请返回</a> </span>";
$this->assign('jumpUrl',__URL__/import);
$msg="格式错误,请重新上传";
$this->success($msg);
}
$savePath="Excel/xls/";
$str = date('Ymdhis');
$file_name=$str.".".$file_type;
if(!copy($tmp_file,$savePath.$file_name)){
//echo "<span style=\"color:red;line-height: 25px;\">上传错误请重试!!<a href=# onclick=history.go(-1);>[返回]</a></span>";
$this->assign('jumpUrl',__URL__/import);
$msg="上传错误,请重新上传";
$this->success($msg);
}else{
$data = new Spreadsheet_Excel_Reader();
$data->setOutputEncoding('utf-8');
$data->read("Excel/xls/".$file_name);
for ($i = 2; $i <= $data->sheets[0]['numRows']; $i++) {
$number=$data->sheets[0]['cells'][$i][1]; $passwd=$data->sheets[0]['cells'][$i][1]; $name=$data->sheets[0]['cells'][$i][2];
$catid=$data->sheets[0]['cells'][$i][3];
$sex=$data->sheets[0]['cells'][$i][4];
$tel=$data->sheets[0]['cells'][$i][5];
$home=$data->sheets[0]['cells'][$i][6];
$minzu=$data->sheets[0]['cells'][$i][7];
$Students=D("Students");
$info=array(
'number'=>$number,
'passwd'=>$passwd,
'name'=>$name,
'catid'=>$catid,
'sex'=>$sex,
'tel'=>$tel,
'home'=>$home,
'minzu'=>$minzu,
);
$Students->create($info);
$Students->add();
}
$this->assign('jumpUrl',__URL__);
$msg="学生信息导入成功";
$this->success($msg);
}
}
}
}
} |
最近公司有个客户需要将几千条的excel表数据导入,给人家导一下吧,以前到也看过一些导入的例子,方法很多,有的转换成csv格式的,txt的,什么都有,但是好多出现乱码情况的,网上PHP读取EXCEL的例子也很多,找了一个很好的类—phpExcelReader ,测试了几次,很不错。 下载地址
下载下后, 更改下 Excel– reader.php 的第31行
require_once 'Spreadsheet/Excel/Reader/OLERead.php';
改为
require_once 'OLERead.ince';
它给的例子的excel我这运行不了, 可能是我装的office的事吧 ^_^。
自己写一个, 现在写一个读取表 插入数据库的实例:
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<?php
require_once 'Excel/reader.php'; //加载所需类
$data = new Spreadsheet_Excel_Reader(); // 实例化
$data->setOutputEncoding('gbk'); //设置编码
$data->read('新建 Microsoft Excel 工作表.xls'); //read函数读取所需EXCEL表,支持中文
$conn= mysql_connect('localhost', 'root', ' ') or die("Can not connect to database."); //连接数据库
mysql_query("set names 'gbk'");//设置编码输出
mysql_select_db('excel'); //选择数据库
for ($i = 2; $i <= $data->sheets[0]['numRows']; $i++) {
$sql = "INSERT INTO test 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]."')";
echo $sql.'<br />';
//$insert = mysql_query($sql); 插入部分 注释掉,实际可以自己插入。
}
?>
注意事项
我这的 for $i=2 是从表的第二行开始(一般第一行都得是字段说明,就不插入数据库了。)
注意sheet段
numRows 为你表的行数
cells 表的列数,示例中 插入的是6列的excel表
如果excel是上传的,先上传然后在读取路径 表名,插入数据库。
Recent Comments