PHP实现数据导入、CSV文件下载的例子
导入、导出CSV文件
代码:
代码如下 | 复制代码 |
class csv /** public function __destruct() /** /** return $tmp; |
这里我们主要用到了php fgetcsv函数、fputcsv函数。
CSV文件下载
代码如下 | 复制代码 |
function exportUserTask() $handle = fopen('php://output', "w"); //表头 www.111cn.net foreach($result as $value) fclose($handle); |
需要提醒的是在导入、导出数据过程注意中文乱码问题,这主要是数据编码格式问题,使用过程根据实际情况对数据进行转码。
PHPExcel 是用来操作Office Excel 文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格导出类
PHPExcel类导出excel,同时对PHPExcel做了些精简处理,基本上可以满足数据导出excel的功能
代码如下:
<?php
代码如下 | 复制代码 |
//载入PHPExcel类 //创建一个excel对象实例 //设置文档基本属性 //设置当前的sheet索引,用于后续的内容操作。 //设置当前活动sheet的名称 //设置单元格内容www.111cn.net $objPHPExcel->getActiveSheet()->SetCellValue('B1', 'b1'); $objPHPExcel->getActiveSheet()->SetCellValue('C1', 'c1'); //输出文档 //设置header头部信息,并输出到浏览器 //保存至某一位置
|
导入excel的方法:
代码:
代码如下 | 复制代码 |
<?php $Obj = new PHPExcel_Reader_Excel5(); //读取demo.xls文件 //获取当前活动sheet //获取行数 //获取列数 //循环输出数据 www.111cn.net echo '<pre>'; |
但是这种方式有缺陷,老版本的excel有个数据上限,最多65536行数据,这时我们就无法通过excel来实现大数据的导出, 但我估计也没几个有这么我数据吧,当然如果有可以考虑使用csv来操作
下面我们一起来看一个PHP模拟QQ登录,发送和接收信息的例子,希望此例子对各位同学会有所帮助。代码如下 | 复制代码 |
$data = getMsg($sid,’接收信息的QQ’); //获取和某个帐号的聊天记录 if(!empty($data)){ function qqLogin($qq_num,$qq_pwd){ //登录帐号 function sendMsg($sid,$to_num,$msg){ //发送消息 } function getMsg($sid,$qq_num) { //获取消息 function httpGet($url,$header=0){ //GET请求 function httpPost($url,$data,$header=0){ //POST请求 function curlRun($opt){ ?> |
代码如下 | 复制代码 |
//字节换算 function conversion($size) { $kb = 1024; // 1KB(Kibibyte,千字节)=1024B, $mb = 1024 * $kb; //1MB(Mebibyte,兆字节,简称“兆”)=1024KB, $gb = 1024 * $mb; // 1GB(Gigabyte,吉字节,又称“千兆”)=1024MB, $tb = 1024 * $gb; // 1TB(Terabyte,万亿字节,太字节)=1024GB, $pb = 1024 * $tb; //1PB(Petabyte,千万亿字节,拍字节)=1024TB, $fb = 1024 * $pb; //1EB(Exabyte,百亿亿字节,艾字节)=1024PB, $zb = 1024 * $fb; //1ZB(Zettabyte,十万亿亿字节,泽字节)= 1024EB, $yb = 1024 * $zb; //1YB(Yottabyte,一亿亿亿字节,尧字节)= 1024ZB, $bb = 1024 * $yb; //1BB(Brontobyte,一千亿亿亿字节)= 1024YB if ($size < $kb) { return $size . " B"; } else if ($size < $mb) { return round($size / $kb, 2) . " KB"; } else if ($size < $gb) { return round($size / $mb, 2) . " MB"; } else if ($size < $tb) { return round($size / $gb, 2) . " GB"; } else if ($size < $pb) { return round($size / $tb, 2) . " TB"; } else if ($size < $fb) { return round($size / $pb, 2) . " PB"; } else if ($size < $zb) { return round($size / $fb, 2) . " EB"; } else if ($size < $yb) { return round($size / $zb, 2) . " ZB"; } else { return round($size / $bb, 2) . " YB"; } } |
先思考一个问题:
如下代码会向页面显示什么?
代码如下 | 复制代码 |
<?php die(123); ?> |
曾经有段时间我一直认为 页面会显示 123,但实践结果告诉我,答案错了,页面一片空白!
一直不知道为什么,死活不输出123,为了让页面输出123,我把它修改为如下代码:
代码如下 | 复制代码 |
<?php echo '123'; die(); ?> |
网络上的一段资料:
PHP中exit()与die()的区别
PHP手册:die()Equivalent to exit()。
说明:die()和exit()都是中止脚本执行函数;其实exit和die这两个名字指向的是同一个函数,die()是exit()函数的别名。该函数只接受一个参数,可以是一个程序返回的数值或是一个字符串,也可以不输入参数,结果没有返回值。
参考:虽然两者相同,但通常使用中也有细微的选择性。例如:
当传递给exit和die函数的值为0时,意味着提前终止脚本的执行,通常用exit()这个名字。
代码如下 | 复制代码 |
echo "1111"; exit(0); echo "2222"; |
// 22222不会被输出,因为程序运行到exit(0)时,脚本已经被提前终止,“马上断气”。
当程序出错时,可以给它传递一个字符串,它会原样输出在系统终端上,通常使用die()这个名字。
代码如下 | 复制代码 |
$fp=fopen("./readme.txt","r") or die("不能打开该文件"); |
2 // 这种情况下,如果fopen函数被调用返回布尔值false时,die()将立即终止脚本,并马上打印
3 // 传递给它的字符串,“死前还能说一两句话”。
--------------------------------------------------------------------------------
回到前面这个话题,下面代码为什么不输出 123 到页面?
代码如下 | 复制代码 |
<?php die(123); // 或 exit(123); ?> |
自己总结:
1、功能上,die() 就等同于 exit();
2、PHP有多种运行方式,即可网站形式,也可脚本形式(不需要Web服务器)。
当PHP为脚本形式运行时,建议用exit():
比如说 Bash Shell脚本语言,当它要停止运行时,会用 exit()函数终止脚本,并允许输出点内容到运行环境(一般是存储到一个全局变量中),但输出的内容只能是 数字,表示“命令的结束状态”。
也就是说,exit(123)只是输出一种运行状态123,而不是真的要向控制台输出 123。如果要向控制台输出123,代码得改成如下形式:
代码如下 | 复制代码 |
exit('123'); |
当PHP为网站形式运行时,建议用die():
但此时 die(数字),就没啥意义,因为它不会向页面输出 数字 字符串,也就是说,如果想让页面终止并且输出数字的话,得改成如下形式
代码如下 | 复制代码 |
<?php die('123'); ?> |
相关文章
- 下面小编来给大家演示几个php操作zip文件的实例,我们可以读取zip包中指定文件与删除zip包中指定文件,下面来给大这介绍一下。 从zip压缩文件中提取文件 代...2016-11-25
Jupyter Notebook读取csv文件出现的问题及解决
这篇文章主要介绍了JupyterNotebook读取csv文件出现的问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2023-01-06- 有时我们接受或下载到的PSD文件打开是空白的,那么我们要如何来解决这个 问题了,下面一聚教程小伙伴就为各位介绍Photoshop打开PSD文件空白解决办法。 1、如我们打开...2016-09-14
- C#使用System.IO中的文件操作方法在Windows系统中处理本地文件相当顺手,这里我们还总结了在Oracle中保存文件的方法,嗯,接下来就来看看整理的C#操作本地文件及保存文件到数据库的基本方法总结...2020-06-25
- 这篇文章主要介绍了解决python 使用openpyxl读写大文件的坑,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-03-13
- 这篇文章主要介绍了C#实现HTTP下载文件的方法,包括了HTTP通信的创建、本地文件的写入等,非常具有实用价值,需要的朋友可以参考下...2020-06-25
- 这篇文章主要为大家详细介绍了SpringBoot实现excel文件生成和下载,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-02-09
php无刷新利用iframe实现页面无刷新上传文件(1/2)
利用form表单的target属性和iframe 一、上传文件的一个php教程方法。 该方法接受一个$file参数,该参数为从客户端获取的$_files变量,返回重新命名后的文件名,如果上传失...2016-11-25- 这篇文章主要介绍了C#使用StreamWriter写入文件的方法,涉及C#中StreamWriter类操作文件的相关技巧,需要的朋友可以参考下...2020-06-25
- 要替换字符串中的内容我们只要利用php相关函数,如strstr,str_replace,正则表达式了,那么我们要替换目录所有文件的内容就需要先遍历目录再打开文件再利用上面讲的函数替...2016-11-25
- 又码了一个周末的代码,这次在做一些关于文件上传的东西。(PHP UPLOAD)小有收获项目是一个BT种子列表,用户有权限上传自己的种子,然后配合BT TRACK服务器把种子的信息写出来...2016-11-25
- 今天小编在这里就来给photoshop的这一款软件的使用者们来说下AI源文件转photoshop图像变模糊问题的解决教程,各位想知道具体解决方法的使用者们,那么下面就快来跟着小编...2016-09-14
- 这篇文章主要介绍了C++万能库头文件在vs中的安装步骤(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
- 步骤:Window -> PHP -> Editor -> Templates,这里可以设置(增、删、改、导入等)管理你的模板。新建文件注释、函数注释、代码块等模板的实例新建模板,分别输入Name、Description、Patterna)文件注释Name: 3cfileDescriptio...2013-10-04
- 这篇文章主要介绍了C#路径,文件,目录及IO常见操作,较为详细的分析并汇总了C#关于路径,文件,目录及IO常见操作,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 本篇文章主要说明的是与php文件上传的相关配置的知识点。PHP文件上传功能配置主要涉及php.ini配置文件中的upload_tmp_dir、upload_max_filesize、post_max_size等选项,下面一一说明。打开php.ini配置文件找到File Upl...2015-10-21
ant design中upload组件上传大文件,显示进度条进度的实例
这篇文章主要介绍了ant design中upload组件上传大文件,显示进度条进度的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-10-29- 举一个案例:复制代码 代码如下:<?phpclass Downfile { function downserver($file_name){$file_path = "./img/".$file_name;//转码,文件名转为gb2312解决中文乱码$file_name = iconv("utf-8","gb2312",$file_name...2014-06-07
- 这篇文章主要介绍了C#实现写入文本文件内容的方法,涉及C#针对文本文件的判断、创建及写入等相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下...2020-06-25
- 通常php.ini的位置在:复制代码 代码如下:/etc目录下或/usr/local/lib目录下。如果你还是找不到php.ini或者找到了php.ini修改后不生效(其实是没找对),请使用如下办法:1.新建php文件,写入如下代码复制代码 代码如下:<?phpe...2014-05-31