在网上找了很多excel导出和导入示例,代码不是很简洁,很多出错,自己在excel方法和控制器改了下。
首先我们看下导出的HTML<a>导出</a>
接着我们看下Index/excelExport 导出的PHP代码:$list = M("user")->field("id,username,password")->order("id DESC")->limit(50)->select(); <br>
$title = array('ID', '用户名', '密码'); //设置要导出excel的表头 <br>
exportExcel($list, '素材火', $title);
exportExcel方法如下:function exportExcel($data, $savefile = null, $title = null, $sheetname = 'sheet1') { <br>
import("Org.Util.PHPExcel"); <br>
//若没有指定文件名则为当前时间戳 <br>
if (is_null($savefile)) { <br>
$savefile = time(); <br>
} <br>
//若指字了excel表头,则把表单追加到正文内容前面去 <br>
if (is_array($title)) { <br>
array_unshift($data, $title); <br>
} <br>
$objPHPExcel = new \PHPExcel(); <br>
//Excel内容 <br>
$head_num = count($data); <br>
<br>
foreach ($data as $k => $v) { <br>
$obj = $objPHPExcel->setActiveSheetIndex(0); <br>
$row = $k + 1; //行 <br>
$nn = 0; <br>
<br>
foreach ($v as $vv) { <br>
$col = chr(65 + $nn); //列 <br>
$obj->setCellValue($col . $row, $vv); //列,行,值 <br>
$nn++; <br>
} <br>
} <br>
//设置列头标题 <br>
for ($i = 0; $i
$alpha = chr(65 + $i); <br>
$objPHPExcel->getActiveSheet()->getColumnDimension($alpha)->setAutoSize(true); //单元宽度自适应 <br>
$objPHPExcel->getActiveSheet()->getStyle($alpha . '1')->getFont()->setName("Candara"); //设置字体 <br>
$objPHPExcel->getActiveSheet()->getStyle($alpha . '1')->getFont()->setSize(12); //设置大小 <br>
$objPHPExcel->getActiveSheet()->getStyle($alpha . '1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_BLACK); //设置颜色 <br>
$objPHPExcel->getActiveSheet()->getStyle($alpha . '1')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER); //水平居中 <br>
$objPHPExcel->getActiveSheet()->getStyle($alpha . '1')->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER); //垂直居中 <br>
$objPHPExcel->getActiveSheet()->getStyle($alpha . '1')->getFont()->setBold(true); //加粗 <br>
} <br>
<br>
$objPHPExcel->getActiveSheet()->setTitle($sheetname); //题目 <br>
$objPHPExcel->setActiveSheetIndex(0); //设置当前的sheet <br>
header('Content-Type: application/vnd.ms-excel'); <br>
header('Content-Disposition: attachment;filename="' . $savefile . '.xls"'); //文件名称 <br>
header('Cache-Control: max-age=0'); <br>
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007'); //Excel5 Excel2007 <br>
$objWriter->save('php://output'); <br>
}
接着我们看下导入的表单:<form> <br>
<div> <br>
<label>Excel表格:</label> <br>
<input> <br>
</div> <br>
<div> <br>
<input> <br>
</div> <br>
</form>
thinkphp上传Index/upload:$upload = new \Think\Upload(); // 实例化上传类 <br>
$upload->maxSize = 3145728; // 设置附件上传大小 <br>
$upload->exts = array('xls', 'xlsx'); // 设置附件上传类 <br>
$upload->savePath = '/'; // 设置附件上传目录 <br>
// 上传文件 <br>
$info = $upload->uploadOne($_FILES['file']); <br>
$filename = 'Uploads' . $info['savepath'] . $info['savename']; <br>
$exts = $info['ext']; <br>
if (!$info) {// 上传错误提示错误信息 <br>
$this->error($upload->getError()); <br>
} else {// 上传成功 <br>
$this->goods_import($filename, $exts); <br>
}
goods_import导入方法:function goods_import($filename, $exts = 'xls') { <br>
//导入PHPExcel类库,因为PHPExcel没有用命名空间,只能inport导入 <br>
import("Org.Util.PHPExcel"); <br>
//创建PHPExcel对象,注意,不能少了\ <br>
$PHPExcel = new \PHPExcel(); <br>
//如果excel文件后缀名为.xls,导入这个类 <br>
<br>
if ($exts == 'xls') { <br>
import("Org.Util.PHPExcel.Reader.Excel5"); <br>
$PHPReader = new \PHPExcel_Reader_Excel5(); <br>
} else if ($exts == 'xlsx') { <br>
import("Org.Util.PHPExcel.Reader.Excel2007"); <br>
$PHPReader = new \PHPExcel_Reader_Excel2007(); <br>
} <br>
//载入文件 <br>
$PHPExcel = $PHPReader->load($filename); <br>
//获取表中的第一个工作表,如果要获取第二个,把0改为1,依次类推 <br>
$currentSheet = $PHPExcel->getSheet(0); <br>
//获取总列数 <br>
$allColumn = $currentSheet->getHighestColumn(); <br>
//获取总行数 <br>
$allRow = $currentSheet->getHighestRow(); <br>
//循环获取表中的数据,$currentRow表示当前行,从哪行开始读取数据,索引值从0开始 <br>
for ($currentRow = 1; $currentRow
//从哪列开始,A表示第一列 <br>
for ($currentColumn = 'A'; $currentColumn
//数据坐标 <br>
$address = $currentColumn . $currentRow; <br>
//读取到的数据,保存到数组$arr中 <br>
$data[$currentRow][$currentColumn] = $currentSheet->getCell($address)->getValue(); <br>
} <br>
} <br>
$this->save_import($data); <br>
}
phpexcel导入和导出演示下载:http://www.sucaihuo.com/php/140.html
AD:真正免费,域名+虚机+企业邮箱=0元

了解Python编程的入门级代码示例Python是一种简单易学,功能强大的编程语言。对于初学者来说,了解Python编程的入门级代码示例是非常重要的。本文将为您提供一些具体的代码示例,帮助您快速入门。打印HelloWorldprint("HelloWorld")这是Python中最简单的代码示例。print()函数用于将指定的内容输出

PHP变量存储程序运行期间的值,对于构建动态且交互式的WEB应用程序至关重要。本文将深入探讨php变量,并通过10个真实的示例展示它们的实际应用。1.存储用户输入$username=$_POST["username"];$passWord=$_POST["password"];此示例从表单提交中提取用户名和密码,并将其存储在变量中以供进一步处理。2.设置配置值$database_host="localhost";$database_username="username";$database_pa

标题:从入门到精通:Go语言中常用数据结构的代码实现数据结构在编程中起着至关重要的作用,它是程序设计的基础。在Go语言中,有许多常用的数据结构,掌握这些数据结构的实现方式对于成为一名优秀的程序员至关重要。本文将介绍Go语言中常用的数据结构,并给出相应的代码示例,帮助读者从入门到精通这些数据结构。1.数组(Array)数组是一种基本的数据结构,是一组相同类型

Java冒泡排序最简单的代码示例冒泡排序是一种常见的排序算法,它的基本思想是通过相邻元素的比较和交换来将待排序序列逐步调整为有序序列。下面是一个简单的Java代码示例,演示了如何实现冒泡排序:publicclassBubbleSort{publicstaticvoidbubbleSort(int[]arr){int

《Go语言编程实例:Web开发中的代码示例》随着互联网的快速发展,Web开发已经成为各行业中必不可少的一部分。作为一门功能强大且性能优越的编程语言,Go语言在Web开发中越来越受到开发者们的青睐。本文将通过具体的代码示例,介绍如何利用Go语言进行Web开发,让读者能够更好地理解和运用Go语言来构建自己的Web应用。1.简单的HTTP服务器首先,让我们从一个

如何使用PHP编写库存管理系统中的库存分仓管理功能代码库存管理是许多企业中不可或缺的一部分。对于拥有多个仓库的企业来说,库存分仓管理功能尤为重要。通过合理管理和跟踪库存,企业可以实现不同仓库之间的库存调拨,优化运营成本,改善协同效率。本文将介绍如何使用PHP编写库存分仓管理功能的代码,并为您提供相关的代码示例。一、建立数据库在开始编写库存分仓管理功能的代码之

Java选择排序法代码编写指南及示例选择排序是一种简单直观的排序算法,其思想是每次从未排序的元素中选择最小(或最大)的元素进行交换,直到所有元素排序完成。本文将提供选择排序的代码编写指南,并附上具体的Java示例代码。算法原理选择排序的基本原理是将待排序数组分为已排序和未排序两部分,每次从未排序部分选择最小(或最大)的元素,将其放到已排序部分的末尾。重复上述

华为云边缘计算对接指南:Java代码示例快速实现接口随着物联网技术的快速发展和边缘计算的兴起,越来越多的企业开始关注边缘计算的应用。华为云提供了边缘计算服务,为企业提供了高可靠的计算资源和便捷的开发环境,使得边缘计算应用更加容易实现。本文将介绍如何通过Java代码快速实现华为云边缘计算的接口。首先,我们需要准备好开发环境。确保你已经安装了Java开发工具包(


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.
