当前位置:首页 » 文件传输 » thinkphp上传excel
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

thinkphp上传excel

发布时间: 2022-01-16 03:01:31

㈠ thinkphp怎么把excel导入数据

Thinkphp使用PHPExcel实现导出Excel
//导出Excel表格
public function export($data,$excelFileName,$sheetTitle){

$this->__construct();
/* 实例化类 */
$objPHPExcel = new PHPExcel();

/* 设置输出的excel文件为2007兼容格式 */
//$objWriter=new PHPExcel_Writer_Excel5($objPHPExcel);//非2007格式
$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);

/* 设置当前的sheet */
$objPHPExcel->setActiveSheetIndex(0);

$objActSheet = $objPHPExcel->getActiveSheet();

/*设置宽度*/
$objPHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(10);
$objPHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(60);

/* sheet标题 */
$objActSheet->setTitle($sheetTitle);

$i = 2;
foreach($data as $value)
{
/* excel文件内容 */
$j = 'A';
foreach($value as $value2)
{
// $value2=iconv("gbk","utf-8",$value2);
$objActSheet->setCellValue($j.$i,$value2);
$j++;
}
$i++;
}

/* 生成到浏览器,提供下载 */
ob_end_clean(); //清空缓存
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate,post-check=0,pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");
header('Content-Disposition:attachment;filename="'.$excelFileName.'.xlsx"');
header("Content-Transfer-Encoding:binary");
$objWriter->save('php://output');

㈡ thinkPHP做上传excel然后要求在网页中显示出Excel的内容怎么做

用phpexcel 来导出里面的数据啊 然后再用数据 在页面上展示就好了

㈢ thinkphp 怎么把数据库导入excel

本文实例讲述了thinkPHP实现将excel导入到数据库中的方法。分享给大家供大家参考,具体如下: PHPExcel插件可点击此处本站下载。 这里使用的是thinkphp框架的3.1版本,下载好压缩包,框架中的extend中的vendor文件夹中新建一个名为PHPExcel的文件夹,把classes里面的内容放到里面 下面是前端页面 提示:我在测试的时候遇到报错exception 'PHPExcel_Reader_Exception' with message 'The filename 原因是由于excel的文件后缀可能不同,我的文件后缀是xlsx,然后给把他另存为了xls的文件,就可以了 <html> <head> </head> <body> <form action="{pigcms::U('Jdb/abcdefgwulisuibian')}" method="post" enctype="multipart/form-data"> <input type="file" name="import"/> <input type="hidden" name="table" value="tablename"/> <input type="submit" value="导入"/> </form> </body> </html> 下面是php的 function abcdefgwulisuibianuplod(){ $this->display();//显示页面 } function abcdefgwulisuibian(){ if (!empty($_FILES)) { import("@.ORG.UploadFile"); $config=array( 'allowExts'=>array('xlsx','xls'), 'savePath'=>'./Public/upload/', 'saveRule'=>'time', ); $upload = new UploadFile($config); if (!$upload->upload()) { $this->error($upload->getErrorMsg()); } else { $info = $upload->getUploadFileInfo(); } vendor("PHPExcel.PHPExcel"); $file_name=$info[0]['savepath'].$info[0]['savename']; $objReader = PHPExcel_IOFactory::createReader('Excel5'); $objPHPExcel = $objReader->load($file_name,$encode='utf-8'); $sheet = $objPHPExcel->getSheet(0); $highestRow = $sheet->getHighestRow(); // 取得总行数 $highestColumn = $sheet->getHighestColumn(); // 取得总列数 for($i=2;$i<=$highestRow;$i++)//这个地方根据需要,一般第一行是名称,所以从第二行开始循环,也可以从第一行开始 { $data['lianjieid'] = $objPHPExcel->getActiveSheet()->getCell("A".$i)->getValue();//数据库字段和excel列相对应 $data['yaoqingma'] = $objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue(); $data['dlmima']= $objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue(); $data['ljdi']= $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue(); M('jdb')->add($data);//插入数据库 } $this->success('导入成功!'); }else { $this->error("请选择上传的文件"); } } 更多关于thinkPHP相关内容感兴趣的读者可查看本站专题:《ThinkPHP入门教程》、《ThinkPHP常用方法总结》、《smarty模板入门基础教程》及《PHP模板技术总结》。 希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。

㈣ thinkphp5.0 如何导入phpexcel插件,能详细些点吗

在tp5.0的根目录找到extend文件夹,然后将phpexcel文件夹放到这里面,然后项目里面引入

//引入extend/phpexcel/PHPExcel.php
import('phpexcel.PHPExcel',EXTEND_PATH);
//实例化PHPExcel
$objPHPExcel=newPHPExcel();

㈤ 如何利用ThinkPHP框架实现Excel数据导入和导出

首先,将PHPExcel文件放入到vendor目录下面:

备注:ThinkPHP3.1的路径是:./ThinkPHP/Extend/Vendor/;ThinkPHP3.2的路径是:./ThinkPHP/Library/Vendor/;

数据导出功能的实现:

编写导出为Excel的函数exportExcel。

㈥ thinkphp使用phpexcel通过excel上传数据到数据库报错:

可能是你excel格式不规范
我用的也是tp的框架,操作excel时,没有问题的

㈦ thinkphp中怎样用php导入excel数据表格

用phpexcel呢,不过对于这个我还是不太熟悉,只能帮到你这一点,呵呵

㈧ ThinkPHP 3.2 + PHPExcel 怎么做批量上传excel 最好能个我个完整的demo感激不尽

用PHPExcel,PHPExcel是相当强大的 MS Office Excel 文档生成类库。

你上它的官/网把程序包下/载下来,里面有 PHPExcel 的程序、还有30个实例程序和三个文档。
看一下其中的开发文档你就会用了。

读取(这段在开发文档里有的,在13页):
require_once '../Classes/PHPExcel/IOFactory.php';

$objReader = PHPExcel_IOFactory::createReader('Excel2007');
$objReader->setReadDataOnly(true);

$objPHPExcel = $objReader->load("test.xlsx");
$objWorksheet = $objPHPExcel->getActiveSheet();

echo '<table>' . "\n";
foreach ($objWorksheet->getRowIterator() as $row) {
echo '<tr>' . "\n";
$cellIterator = $row->getCellIterator();
$cellIterator->setIterateOnlyExistingCells(false);
foreach ($cellIterator as $cell) {
echo '<td>' . $cell->getValue() . '</td>' . "\n";
}
echo '</tr>' . "\n";
}
echo '</table>' . "\n";
?>

㈨ thinkphp3.1中的phpexcel导入怎么用

首先,去PHPExcel官方网站下载PHPExcel,官方地址为;http://phpexcel.codeplex.com/.我下的是1.8.0版本的.解压后发现还是蛮大的,有十几M,不知道其他版本是不是会小点.
这里写图片描述
把解压好的PHPExcel文件放在ThinkPHP的Vender文件夹下(专门放第三方类库的),如下图
这里写图片描述
其次,创建Excel转换数组类,并把它放在ThinkPHP\Extend\Library\ORG\Util目录下
class ExcelToArrary {
public function __construct() {
Vendor("PHPExcel.Classes.PHPExcel");//引入phpexcel类(留意路径,不了解路径可以查看下手册)
Vendor("PHPExcel.Classes.PHPExcel.IOFactory"); //引入phpexcel类(留意路径)
}
public function read($filename,$encode,$file_type){
if(strtolower ( $file_type )=='xls')//判断excel表类型为2003还是2007
{
Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel5"); //引入phpexcel类(留意路径)
$objReader = PHPExcel_IOFactory::createReader('Excel5');
}elseif(strtolower ( $file_type )=='xlsx')
{
Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel2007");//引入phpexcel类(留意路径)
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
}
$objReader->setReadDataOnly(true);
$objPHPExcel = $objReader->load($filename);
$objWorksheet = $objPHPExcel->getActiveSheet();
$highestRow = $objWorksheet->getHighestRow();
$highestColumn = $objWorksheet->getHighestColumn();
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
$excelData = array();
for ($row = 1; $row <= $highestRow; $row++) {
for ($col = 0; $col < $highestColumnIndex; $col++) {
$excelData[$row][] =(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
}
}
return $excelData;
}
}
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
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
如右图这里写图片描述
现在来说Excel,表格的结构样式和MySQL样式要类似,表格样式如下(本人对Excel使用只是一般,所以如果有Excel大神做的报表,不知后果如何).
这里写图片描述
前端页面相关代码:
<div>
<form method="post" action="{:U('Index/upload')}" enctype="multipart/form-data">
<font>导入Excel数据:</font>
<label for="file_stu">上传</label>
<input name="file_stu" type="file" id="file_stu" />
<h3>温馨提示:</h3>
<p>请确认您的Excel表格类型是xls的,以免出现兼容问题.</p>
<inputtypeinputtype="submit" class="sure" value="导入" />
</form>
</div>
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
最后,控制器部分使用了Thinkphp自带的上传类,使用unlink()函数是为了删除上传的excel表格,以免文件夹存入过多文件,调试代码时可先注释掉.或者不写也行,把删除文件的工作交给你们的运维.代码中foreach循环部分$v[]里的0, 1,2可以改动以下看看与Excel表格里的内容是什么关系.可以把数组打印出来看一看,你就很清楚了
相关代码:
public function upload(){
import('ORG.Util.ExcelToArrary');//导入excelToArray类
if (! empty ( $_FILES ['file_stu'] ['name'] )){
import('ORG.Net.UploadFile');
$upload = new UploadFile();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小
$upload->allowExts = array('xls', 'xlsx');// 设置附件上传类型
$upload->savePath = './Uploads/';// 设置附件上传目录
if(!$upload->upload()) {// 上传错误提示错误信息
$this->error($upload->getErrorMsg());
}else{// 上传成功 获取上传文件信息
$info = $upload->getUploadFileInfo();
}
}else{
$this->error('(⊙o⊙)~没传数据就导入?!你在逗我?!');
}
//mp($info);die;
$ExcelToArrary=new ExcelToArrary();//实例化
$res=$ExcelToArrary->read($info[0]['savepath'].$info[0]['savename'],"UTF-8",$info[0]['extension']);//传参,判断office2007还是office2003
$res = array_slice($res,1); //为了去掉Excel里的表头,也就是$res数组里的$res[0];
//mp($res);
foreach ( $res as $k => $v ){ //循环excel表
$data[$k]['mobile'] = $v [0];//创建二维数组
$data[$k]['name'] = $v [1];
$data[$k]['ty'] = $v [2];
}
//mp($data);die;
$result=M('appkey')->addAll($data);
if(!$result){
$this->error('导入数据库失败');
exit();
}else{
$filename = './Uploads/'.$info[0]['savename'];//上传文件绝对路径,unlink()删除文件函数
if (unlink($filename)) {
$this->success ( '导入成功' );
}else{
$this->error('缓存删除失败');
}
}
}

㈩ thinkphp怎么把excel导入数据库

  • thinkPHP实现将excel导入到数据库中的方法体如下:

PHPExcel插件可点击此处本站下载。

这里使用的是thinkphp框架的3.1版本,下载好压缩包,框架中的extend中的vendor文件夹中新建一个名为PHPExcel的文件夹,把classes里面的内容放到里面

下面是前端页面

提示:我在测试的时候遇到报错exception 'PHPExcel_Reader_Exception' with message 'The filename

原因是由于excel的文件后缀可能不同,我的文件后缀是xlsx,然后给把他另存为了xls的文件,就可以了

<html>

<head>

</head>

<body>

<form action="{pigcms::U('Jdb/abcdefgwulisuibian')}" method="post" enctype="multipart/form-data">

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

<input type="hidden" name="table" value="tablename"/>

<input type="submit" value="导入"/>

</form>

</body>

</html>


下面是php的

function abcdefgwulisuibianuplod(){

$this->display();//显示页面

}

function abcdefgwulisuibian(){

if (!empty($_FILES)) {

import("@.ORG.UploadFile");

$config=array(

'allowExts'=>array('xlsx','xls'),

'savePath'=>'./Public/upload/',

'saveRule'=>'time',

);

$upload = new UploadFile($config);

if (!$upload->upload()) {

$this->error($upload->getErrorMsg());

} else {

$info = $upload->getUploadFileInfo();

}

vendor("PHPExcel.PHPExcel");

$file_name=$info[0]['savepath'].$info[0]['savename'];

$objReader = PHPExcel_IOFactory::createReader('Excel5');

$objPHPExcel = $objReader->load($file_name,$encode='utf-8');

$sheet = $objPHPExcel->getSheet(0);

$highestRow = $sheet->getHighestRow(); // 取得总行数

$highestColumn = $sheet->getHighestColumn(); // 取得总列数

for($i=2;$i<=$highestRow;$i++)//这个地方根据需要,一般第一行是名称,所以从第二行开始循环,也可以从第一行开始

{

$data['lianjieid'] = $objPHPExcel->getActiveSheet()->getCell("A".$i)->getValue();//数据库字段和excel列相对应

$data['yaoqingma'] = $objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue();

$data['dlmima']= $objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue();

$data['ljdi']= $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue();

M('jdb')->add($data);//插入数据库

}

$this->success('导入成功!');

}else

{

$this->error("请选择上传的文件");

}

}