thinkphp实现excel数据的导入导出的实例代码
实现步骤:
一:在http://phpexcel.codeplex.com/下载最新PHPExcel放到Vendor下,注意位置:ThinkPHP\Extend\Vendor\PHPExcel\PHPExcel.php。
二:导出excel代码实现
/**方法**/
functionindex(){
$this->display();
}
publicfunctionexportExcel($expTitle,$expCellName,$expTableData){
$xlsTitle= iconv('utf-8','gb2312',$expTitle);//文件名称
$fileName=$_SESSION['account'].date('_YmdHis');//or $xlsTitle 文件名称可根据自己情况设定
$cellNum=count($expCellName);
$dataNum=count($expTableData);
vendor("PHPExcel.PHPExcel");
$objPHPExcel=newPHPExcel();
$cellName=array('A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','AA','AB','AC','AD','AE','AF','AG','AH','AI','AJ','AK','AL','AM','AN','AO','AP','AQ','AR','AS','AT','AU','AV','AW','AX','AY','AZ');
$objPHPExcel->getActiveSheet(0)->mergeCells('A1:'.$cellName[$cellNum-1].'1');//合并单元格
// $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1', $expTitle.' Export time:'.date('Y-m-d H:i:s'));
for($i=0;$i<$cellNum;$i++){
$objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i].'2',$expCellName[$i][1]);
}
// Miscellaneous glyphs, UTF-8
for($i=0;$i<$dataNum;$i++){
for($j=0;$j<$cellNum;$j++){
$objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j].($i+3),$expTableData[$i][$expCellName[$j][0]]);
}
}
header('pragma:public');
header('Content-type:application/vnd.ms-excel;charset=utf-8;name="'.$xlsTitle.'.xls"');
header("Content-Disposition:attachment;filename=$fileName.xls");//attachment新窗口打印inline本窗口打印
$objWriter= PHPExcel_IOFactory::createWriter($objPHPExcel,'Excel5');
$objWriter->save('php://output');
exit;
}
/**
*
* 导出Excel
*/
functionexpUser(){//导出Excel
$xlsName="User";
$xlsCell=array(
array('id','账号序列'),
array('truename','名字'),
array('sex','性别'),
array('res_id','院系'),
array('sp_id','专业'),
array('class','班级'),
array('year','毕业时间'),
array('city','所在地'),
array('company','单位'),
array('zhicheng','职称'),
array('zhiwu','职务'),
array('jibie','级别'),
array('tel','电话'),
array('qq','qq'),
array('email','邮箱'),
array('honor','荣誉'),
array('remark','备注')
);
$xlsModel= M('Member');
$xlsData=$xlsModel->Field('id,truename,sex,res_id,sp_id,class,year,city,company,zhicheng,zhiwu,jibie,tel,qq,email,honor,remark')->select();
foreach($xlsDataas$k=>$v)
{
$xlsData[$k]['sex']=$v['sex']==1?'男':'女';
}
$this->exportExcel($xlsName,$xlsCell,$xlsData);
}
|
第三:导入excel数据代码
functionimpUser(){
if(!empty($_FILES)) {
import("@.ORG.UploadFile");
$config=array(
'allowExts'=>array('xlsx','xls'),
'savePath'=>'./Public/upload/',
'saveRule'=>'time',
);
$upload=newUploadFile($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=3;$i<=$highestRow;$i++)
{
$data['account']=$data['truename'] =$objPHPExcel->getActiveSheet()->getCell("B".$i)->getValue();
$sex=$objPHPExcel->getActiveSheet()->getCell("C".$i)->getValue();
// $data['res_id'] = $objPHPExcel->getActiveSheet()->getCell("D".$i)->getValue();
$data['class'] =$objPHPExcel->getActiveSheet()->getCell("E".$i)->getValue();
$data['year'] =$objPHPExcel->getActiveSheet()->getCell("F".$i)->getValue();
$data['city']=$objPHPExcel->getActiveSheet()->getCell("G".$i)->getValue();
$data['company']=$objPHPExcel->getActiveSheet()->getCell("H".$i)->getValue();
$data['zhicheng']=$objPHPExcel->getActiveSheet()->getCell("I".$i)->getValue();
$data['zhiwu']=$objPHPExcel->getActiveSheet()->getCell("J".$i)->getValue();
$data['jibie']=$objPHPExcel->getActiveSheet()->getCell("K".$i)->getValue();
$data['honor']=$objPHPExcel->getActiveSheet()->getCell("L".$i)->getValue();
$data['tel']=$objPHPExcel->getActiveSheet()->getCell("M".$i)->getValue();
$data['qq']=$objPHPExcel->getActiveSheet()->getCell("N".$i)->getValue();
$data['email']=$objPHPExcel->getActiveSheet()->getCell("O".$i)->getValue();
$data['remark']=$objPHPExcel->getActiveSheet()->getCell("P".$i)->getValue();
$data['sex']=$sex=='男'?1:0;
$data['res_id'] =1;
$data['last_login_time']=0;
$data['create_time']=$data['last_login_ip']=$_SERVER['REMOTE_ADDR'];
$data['login_count']=0;
$data['join']=0;
$data['avatar']='';
$data['password']=md5('123456');
M('Member')->add($data);
}
$this->success('导入成功!');
}else
{
$this->error("请选择上传的文件");
}
}
|
四、模板代码
<html>
<head>
</head>
<body>
<P><ahref="{:U('Index/expUser')}">导出数据并生成excel</a></P><br/>
<formaction="{:U('Index/impUser')}"method="post"enctype="multipart/form-data">
<inputtype="file"name="import"/>
<inputtype="hidden"name="table"value="tablename"/>
<inputtype="submit"value="导入"/>
</form>
</body>
</html>
|
接着上篇《iOS+PHP注册登录系统 PHP部分(上)》进行学习
3.iOS部分
上一次我们写完了数据库部分和PHP部分这次我们来完成iOS部分。
首先先在storyboard中一阵狂拖,弄成如下图。
可以先在text Field中输入用户名和密码 方便以后调试。
3.1登录部分代码
创建一个新的UIViewController 名为registViewController(用于注册用户,ViewController用于登录)。
在ViewController.h中importregistViewController
#import "registViewController.h"
然后设置登录界面中的控件 用来写用户名的控件名设置为txtUser,密码的控件名设置为txtPwd,确定按钮的方法名称为
LoginClick,注册按钮的方法名为registButton。
然后开始写ViewController.m中的代码
//
// ViewController.m
// iosLogin
//
// Created by 曹晗 on 16/2/25.
// Copyright :emoji: 2016年 CaoHan. All rights reserved.
//
#import "ViewController.h"
@interface ViewController ()
@property (weak, nonatomic) IBOutlet UITextField *txtUser;
@property (weak, nonatomic) IBOutlet UITextField *txtPwd;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
- (IBAction)LoginClick:(id)sender {
//前后去空格
NSString *userName = [_txtUser.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
NSString *userPwd = [_txtPwd.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
NSDictionary *jsonDic = [self getJsonData:userName userpwd:userPwd];
NSString* loginFlag = [jsonDic objectForKey:@"loginFlag"];
NSLog(@"%@",loginFlag);
[self aletrInfo:loginFlag];
}
- (IBAction)registButton:(id)sender {
UIStoryboard *storboard = self.storyboard;
registViewController *vc2 = [storboard instantiateViewControllerWithIdentifier:@"vc2"];
[self presentViewController:vc2 animated:YES completion:nil];
}
//用于请求PHP 获得JSON
- (NSDictionary *)getJsonData:(NSString *)user_name userpwd:(NSString *)user_pwd {
NSError *error;
NSString *urlString = [NSString stringWithFormat:@"http://192.168.1.106/iosLogin/index.php?action=login&user_name=%@&user_pwd=%@",user_name,user_pwd];
//加载一个NSURL对象
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:urlString]];
//将请求的url数据放到NSData对象中
NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];
//IOS5自带解析类NSJSONSerialization从response中解析出数据放到字典中
NSDictionary *jsonDic = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:&error];
NSLog(@"接收到的数据为%@",jsonDic);
returnjsonDic;
}
//弹出信息
- (void)aletrInfo:(NSString *)loginFlag{
UIAlertView *alert = [[UIAlertView alloc]init];
[alert setTitle:@"提示"]; [alert setDelegate:nil];
[alert addButtonWithTitle:@"确定"];
if([loginFlag isEqual: @"0"]) {
[alert setMessage:@"账号或密码错误"];
}
if([loginFlag isEqual:@"1"]) {
[alert setMessage:@"登陆成功"];
}
[alert show];
}
@end
|
在注册按钮能够跳转界面前,要先将stroyboard中的注册界面的stroyboard ID设置为vc2才可以进行跳转。
其中这里的192.168.1.106可以写localhost也可以写自己的ip地址。
写到这里就可以先进行调试一下登录了。后面的注册用户代码也和这里差不多。
3.2注册界面代码
先在registViewCongroller.h中import ViewController.h
#import "ViewController.h"
然后是registViewController.m中的代码。
//
// registViewController.m
// iosLogin
//
// Created by 曹晗 on 16/2/27.
// Copyright 2016年 CaoHan. All rights reserved.
//
#import "registViewController.h"
@interface registViewController ()
@property (weak, nonatomic) IBOutlet UITextField *txtUser;
@property (weak, nonatomic) IBOutlet UITextField *txtPwd;
@end
@implementation registViewController
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view.
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}
//这个是注册按钮
- (IBAction)registButton:(id)sender {
NSString *userName = [_txtUser.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
NSString *userPwd = [_txtPwd.text stringByTrimmingCharactersInSet:[NSCharacterSet whitespaceCharacterSet]];
NSDictionary *jsonDic = [self getJsonData:userName userpwd:userPwd];
NSString* registFlag = [jsonDic objectForKey:@"registFlag"];
NSLog(@"%@",registFlag);
[self aletrInfo:registFlag];
}
//这个是返回按钮
- (IBAction)returnButton:(id)sender {
[self dismissModalViewControllerAnimated:YES];
}
- (NSDictionary *)getJsonData:(NSString *)user_name userpwd:(NSString *)user_pwd {
NSError *error;
NSString *urlString = [NSString stringWithFormat:@"http://192.168.1.106/iosLogin/index.php?action=regist&user_name=%@&user_pwd=%@",user_name,user_pwd];
//加载一个NSURL对象
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:urlString]];
//将请求的url数据放到NSData对象中
NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];
//IOS5自带解析类NSJSONSerialization从response中解析出数据放到字典中
NSDictionary *jsonDic = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:&error];
NSLog(@"接收到的数据为%@",jsonDic);
returnjsonDic;
}
- (void)aletrInfo:(NSString *)registFlag{
UIAlertView *alert = [[UIAlertView alloc]init];
[alert setTitle:@"提示"]; [alert setDelegate:nil];
[alert addButtonWithTitle:@"确定"];
if([registFlag isEqual: @"0"]) {
[alert setMessage:@"用户名已存在"];
}
if([registFlag isEqual:@"1"]) {
[alert setMessage:@"注册成功"];
}
[alert show];
}
@end
|
最后达成效果:
分析做项目的基本流程:
1.先创建数据库
2.写PHP服务端
3.写iOS用户端
1.创建数据库
我用的是wamp。
数据库名称为ioslogin,表名为users其中有3个字段user_id,user_name和user_pwd。
user_id为自增长。
2.php服务端
php端我用的是EclipsePHP编写。
先创建一个配置文件config.php。
<?php
$DBHOST="localhost";
$DBUSER="root";
$DBPWD="";
$DBNAME="ioslogin";
?>
然后创建主要文件 index.php。
[php] view plaincopy
<?php
header("Content-type:text/html;charset=utf-8");
require_once"config.php";
//连接数据库
$connection= mysql_connect($DBHOST,$DBUSER,$DBPWD);
$db_selecct= mysql_select_db($DBNAME);
$action=$_GET['action']; //用来区分是登录还是注册
$user_name=$_GET['user_name']; //GET方法方便用于调试
$user_pwd=$_GET['user_pwd'];
switch($action) {
case"login":
$str="select * from users where user_name='$user_name' and user_pwd='$user_pwd'";
$result= mysql_query($str,$connection);
@$rows= mysql_num_rows($result);
if($rows) {
$loginFlag="1"; //登录成功
}
else{
$loginFlag="0"; //登录失败
}
$returnArr=array("loginFlag"=>$loginFlag);
echojson_encode($returnArr); //输出json格式
break;
case"regist":
$str="INSERT INTO users (user_name,user_pwd) values ('$user_name','$user_pwd')";
$result= mysql_query($str,$connection);
if($result) {
$registFlag="1";//注册成功
}
else{
$registFlag="0";//注册失败
}
$returnArr=array("registFlag"=>$registFlag);
echojson_encode($returnArr);
break;
default:
echo"登录方式错误";
returnfalse;
break;
}
mysql_close($connection);
?>
|
写到这里 同学们可以先对PHP进行测试看看有没有错误。
可以先在数据库里加一条数据。
然后在浏览器里输入localhost/iosLogin/index.php?action=login&user_name=admin&user_pwd=admin
其中iosLogin是PHP项目名称,有输出json就差不多是正确的。
抓取方法如下
首先在浏览器里打开阅读页面,查看源代码后发现小说的内容并不是直接写在页面里的,也就是说小说的内容是通过异步加载而来的。
于是将chrome的开发者工具切到network一栏,刷新阅读页面,主要关注的是XHR和script两个分类下。
经过排查,发现在script分类下有个jsonp请求比较像是小说内容,请求的地址是
http://wenku.baidu.com/content/49422a3769eae009581becba?m=8ed1dedb240b11bf0731336eff95093f&type=json&cn=1&_=1&t=1423309200&callback=wenku7
返回的是一个jsonp字符串,然后我发现,如果把地址里面的callback=wenku7去掉,返回的就是一个json字符串,这样解析起来就方便不少,可以直接在php里面转换成数组。
再来分析一下返回数据的结构,返回的json字符串之后是一个树状的结构,每个节点都有一个t属性和c属性,t属性用来指明这个节点的标签,比如h2 div等等,c属性就是内容了,但也有两种可能,一个是字符串,另一个是数组,数组的每个元素都是一个节点。
这种结构最好解析了,用一个递归就搞定
最终代码如下:
<?php classBaiduYuedu { protected$bookId; protected$bookToken; protected$cookie; protected$result; publicfunction__construct($bookId,$bookToken,$cookie){ $this->bookId =$bookId; $this->bookToken =$bookToken; $this->cookie =$cookie; } publicstaticfunctionparseNode($node){ $str='' if(is_string($node['c'])){ $str.=$node['c']; }elseif(is_array($node['c'])){ foreach($node['c']as$d){ $str.= self::parseNode($d); } } switch($node['t']){ case'h2': $str.="\n\n"; break; case'br': case'div': case'p': $str.="\n"; break; case'img': case'span': break; case'obj': $tmp='('. self::parseNode($node['data'][0]) .')' $str.=str_replace("\n",'',$tmp); break; default: trigger_error('Unkown type:'.$node['t'], E_USER_WARNING); break; } return$str; } publicfunctionget($page= 1){ echo"getting page {$page}...\n"; $ch= curl_init(); $url= sprintf('http://wenku.baidu.com/content/%s/?m=%s&type=json&cn=%d',$this->bookId,$this->token,$page); curl_setopt_array($ch,array( CURLOPT_URL =>$url, CURLOPT_RETURNTRANSFER => 1, CURLOPT_HEADER => 0, CURLOPT_HTTPHEADER =>array('Cookie: '.$this->cookie) )); $ret= json_decode(curl_exec($ch), true); curl_close($ch); $str='' if(!empty($ret)){ $str.= self::parseNode($ret); $str.=$this->get($page+ 1); } return$str; } publicfunctionstart(){ $this->result =$this->get(); } publicfunctiongetResult(){ return$this->result; } publicfunctionsaveTo($path){ if(empty($this->result)){ trigger_error('Result is empty', E_USER_ERROR); return; } file_put_contents($path,$this->result); echo"save to {$path}\n"; } } //使用示例 $yuedu=newBaiduYuedu(�a3769eae009581becba',Ǝed1dedb240b11bf0731336eff95093f','你的百度域cookie'); $yuedu->start(); $yuedu->saveTo('result.txt'); |
这个类前两个参数可以从小说的介绍页面获得,第一个参数bookId就是url里ebook后面跟着的字符串,第二个参数bookToken在页面源代码搜索bdjsonUrl,m参数后面的那个字符串就是。
注:如果不传入百度cookie或者百度cookie无效,则只能抓取免费阅读部分,要抓完整的内容必须保证cookie可以正常使用。
总结:
以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用PHP能有一定的帮助,如果有疑问大家可以留言交流。
相关文章
- 有一种方法,可以不打开网站而直接查看到这个网站的源代码.. 这样可以有效地防止误入恶意网站... 在浏览器地址栏输入: view-source:http://...2016-09-20
- <?php require('path.inc.php'); header('content-Type: text/html; charset=utf-8'); $borough_id = intval($_GET['id']); if(!$borough_id){ echo ' ...2016-11-25
- 本文实例讲述了JS+CSS实现分类动态选择及移动功能效果代码。分享给大家供大家参考,具体如下:这是一个类似选项卡功能的选择插件,与普通的TAb区别是加入了动画效果,多用于商品类网站,用作商品分类功能,不过其它网站也可以用,...2015-10-21
- 本文实例讲述了JS实现自定义简单网页软键盘效果。分享给大家供大家参考,具体如下:这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学...2015-11-08
- 本文实例讲述了JS基于Mootools实现的个性菜单效果代码。分享给大家供大家参考,具体如下:这里演示基于Mootools做的带动画的垂直型菜单,是一个初学者写的,用来学习Mootools的使用有帮助,下载时请注意要将外部引用的mootools...2015-10-23
- php 取除连续空格与换行代码,这些我们都用到str_replace与正则函数 第一种: $content=str_replace("n","",$content); echo $content; 第二种: $content=preg_replac...2016-11-25
- php简单用户登陆程序代码 这些教程很对初学者来讲是很有用的哦,这款就下面这一点点代码了哦。 <center> <p> </p> <p> </p> <form name="form1...2016-11-25
- 公司一些wordpress网站由于下载的插件存在恶意代码,导致整个服务器所有网站PHP文件都存在恶意代码,就写了个简单的脚本清除。恶意代码示例...2015-10-23
- 其实挺简单的就是if(navigator.userAgent.indexOf('UCBrowser') > -1) {alert("uc浏览器");}else{//不是uc浏览器执行的操作}如果想测试某个浏览器的特征可以通过如下方法获取JS获取浏览器信息 浏览器代码名称:navigator...2015-11-08
- 本文实例讲述了JS实现双击屏幕滚动效果代码。分享给大家供大家参考,具体如下:这里演示双击滚屏效果代码的实现方法,不知道有觉得有用处的没,现在网上还有很多还在用这个特效的呢,代码分享给大家吧。运行效果截图如下:在线演...2015-10-30
- 一、日期减去天数等于第二个日期function cc(dd,dadd){//可以加上错误处理var a = new Date(dd)a = a.valueOf()a = a - dadd * 24 * 60 * 60 * 1000a = new Date(a)alert(a.getFullYear() + "年" + (a.getMonth() +...2015-11-08
- 微信支付,即便交了保证金,你还是处理测试阶段,不能正式发布。必须到你通过程序测试提交订单、发货通知等数据到微信的系统中,才能申请发布。然后,因为在微信中是通过JS方式调用API,必须在微信后台设置支付授权目录,而且要到...2014-05-31
- 本文实例讲述了PHP常用的小程序代码段。分享给大家供大家参考,具体如下:1.计算两个时间的相差几天$startdate=strtotime("2009-12-09");$enddate=strtotime("2009-12-05");上面的php时间日期函数strtotime已经把字符串...2015-11-24
- 小编分享了一段简单的php中文转拼音的实现代码,代码简单易懂,适合初学php的同学参考学习。 代码如下 复制代码 <?phpfunction Pinyin($_String...2017-07-06
php导出csv格式数据并将数字转换成文本的思路以及代码分享
php导出csv格式数据实现:先定义一个字符串 存储内容,例如 $exportdata = '规则111,规则222,审222,规222,服2222,规则1,规则2,规则3,匹配字符,设置时间,有效期'."/n";然后对需要保存csv的数组进行foreach循环,例如复制代...2014-06-07- ecshop商品无限级分类代码 function cat_options($spec_cat_id, $arr) { static $cat_options = array(); if (isset($cat_options[$spec_cat_id]))...2016-11-25
- 本文介绍了如何延迟javascript代码的加载,加快网页的访问速度。 当一个网站有很多js代码要加载,js代码放置的位置在一定程度上将会影像网页的加载速度,为了让我们的网页加载速度更快,本文总结了一下几个注意点...2013-10-13
详解在IDEA中将Echarts引入web两种方式(使用js文件和maven的依赖导入)
这篇文章主要介绍了在IDEA中将Echarts引入web两种方式(使用js文件和maven的依赖导入),本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-07-11- 这篇文章主要介绍了IDEA插件之快速删除Java代码中的注释,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2021-02-18
- 这篇文章主要介绍了C#超实用代码段合集,涉及C#针对图标、数学运算、拼音、日期、时间及文件夹等的相关操作技巧,需要的朋友可以参考下...2020-06-25