php 导出tables,jquery+php实现导出datatables插件数据到excel的方法_php技巧
本文实例讲述了jquery+php实现导出datatables插件数据到excel的方法。分享给大家供大家参考。具体如下:
DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点:
1. 自动分页处理
2. 即时表格数据过滤
3. 数据排序以及数据类型自动检测
4. 自动处理列宽度
5. 可通过CSS定制样式
6. 支持隐藏列
7. 易用
8. 可扩展性和灵活性
9. 国际化
10.动态创建表格
11.免费
插件地址http://www.datatables.net/
不过可惜的是官方网站表格数据导出方法使用的是tabletools插件,利用flash导出数据,而且不支持中文数据,通过查找官方的API和资料,找到使用jquery和php导出数据方法。
导出数据的javascript函数
function table2csv(oTable, exportmode, tableElm) {
var csv = '';
var headers = [];
var rows = [];
// Get header names
$(tableElm+' thead').find('th').each(function() {
var $th = $(this);
var text = $th.text();
var header = '"' + text + '"';
// headers.push(header); // original code
if(text != "") headers.push(header); // actually datatables seems to copy my original headers so there ist an amount of TH cells which are empty
});
csv += headers.join(',') + "\n";
// get table data
if (exportmode == "full") { // total data
var total = oTable.fnSettings().fnRecordsTotal()
for(i = 0; i < total; i++) {
var row = oTable.fnGetData(i);
row = strip_tags(row);
rows.push(row);
}
} else { // visible rows only
$(tableElm+' tbody tr:visible').each(function(index) {
var row = oTable.fnGetData(this);
row = strip_tags(row);
rows.push(row);
})
}
csv += rows.join("\n");
// if a csv div is already open, delete it
if($('.csv-data').length) $('.csv-data').remove();
// open a div with a download link
$('body').append('
'+csv+'');
}
function strip_tags(html) {
var tmp = document.createElement("div");
tmp.innerHTML = html;
return tmp.textContent||tmp.innerText;
}
函数支持导出所有数据和当前页数据
// export only what is visible right now (filters & paginationapplied)
$('#export_visible').click(function(event) {
var oTable;
oTable= $('#spdata').dataTable();
event.preventDefault();
table2csv(oTable, 'visible', '#spdata'); })
// export all table data
$('#export_all').click(function(event) {
var oTable;
oTable= $('#spdata').dataTable();
event.preventDefault();
table2csv(oTable, 'full', '#spdata'); })
其中#spdata是table的id
后台php导出excel代码
header("Content-Type: application/vnd.ms-execl");
header("Content-Disposition: attachment; filename=myExcel.csv");
header("Pragma: no-cache");
header("Expires: 0");
$buffer = $_POST['csv'];
$buffer=str_replace(",",",\t",$buffer);
$buffer=mb_convert_encoding($buffer,"GB2312","UTF-8");
echo $buffer;
希望本文所述对大家的php程序设计有所帮助。
本文原创发布php中文网,转载请注明出处,感谢您的尊重!
php 导出tables,jquery+php实现导出datatables插件数据到excel的方法_php技巧相关推荐
- php导出excel数据代码,phpspreadsheet导出数据到Excel的方法介绍(代码示例)
本篇文章给大家带来的内容是关于phpspreadsheet导出数据到Excel的方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 之前我们使用PHP导出Excel数 ...
- python mysql导出到excel_python:mysql导出数据到excel工具方法
近期肺炎严重,春节期间都在家闭关,闲暇时间捡起了之前学习的python,刚好最近在项目上处理大批量数据,从数据库导出数据效率比较低,就想通过python实现导出,结果效率果然很高,基本5-10秒内就导 ...
- php输出json到表格,Vue如何导出json数据到Excel电子表格方法
本文主要介绍了Vue导出json数据到Excel电子表格的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考,希望能帮助到大家. 一.安装依赖(前面基本一样) npm install file- ...
- QT导出数据到Excel的方法
一.系统库中自带的写入方法写入Excel 使用QAxObject,系统自带的参数. 使用方法参考:https://blog.csdn.net/cannon_qi/article/details/799 ...
- php 导出大数据量excel 解决方法 秒出 并不会出现PHPExcel内存溢出问题
最近公司需要每天生成亚马逊广告调价报告报表 并且文件格式必须为excel 数据量超过10w+ 使用PHPExcel组件 加上生成器yield 并且设置单元格对象缓存 还是会导致内存爆掉 最后使用了PH ...
- C#读取Excel表格数据到DataGridView中和导出DataGridView中的数据到Excel
其实想在datagridview中显示excel表格中的数据跟读取数据库中的数据没什么差别,只不过是创建数据库连接的时候连接字段稍有差别. private void btnShow_Click(obj ...
- JavaScript导出图片和数据到Excel
JavaScript导出图片和数据到Excel 以下方法可以利用json数据将图片地址生成图片导出到Excel,同样也可以将数据导出到Excel.解决网上许多方法关于导出图片到Excel却无法让图片在 ...
- Qt导出数据到excel
Qt导出数据到excel Qt导出数据到excel,方法有很多,Qt里也有自带的axcontainer模块中的#include<QAxObject>类可以导出数据到excel,但是这种方法 ...
- Javascript实现导出word - jquery jquery.wordexport.js 实现导出word
Javascript实现导出word - jquery.wordexport.js 实现导出word 由于工作需要,将一个页面导出word文档,主要是简历!经过百度搜索之后,没找到结果,无奈之下只能求 ...
最新文章
- USB获取图像实时处理
- 在 Virt-manager 图形界面中使用桥接网络
- Input.GetTouch 获取触摸
- PHP生成条形码 之二 开源之道
- Python3爬虫-01-简单网页爬取
- php入门02-数组
- CDN视频流中的3个问题以及解决方法
- JUnit 4和JUnit 5区别
- 基于界面自动化测试框架的发展
- SpringMVC jsp界面值渲染不出来
- 38..Node.js工具模块---底层的网络通信--Net模块
- iOS 开发常用链接总结
- python黑网站_python
- ubuntu docker-compose: command not found
- python爬虫跳过付费数据_Python爬虫教程:包图网免费付费素材爬取!
- 《跨界杂谈》华为印象(二):MTS
- 用turtle绘图做一个钟表时钟
- VR全景制作方法教程完整版
- python剪辑视频 裁剪_用python进行视频剪辑
- android拓展内存卡,都取消存储卡拓展,而它却解决了安卓手机的大问题
热门文章
- 大数据分析平台建模及建议
- 商业数据分析的层次与步骤有哪些
- 阿里天池用Pandas揭秘美国选民的总统喜好附加题
- c语言求一个数因数个数,【代码】求一个数的因数和、求优化、顺便也供新人参考算法...
- emmap erlang_erLang学些笔记2—基本类型
- Linux中yum不能用的原因
- 微信jssdk配置的问题,使用MVC制作的demo
- 谈谈MySQL InnoDB存储引擎事务的ACID特性
- Python 爬虫 (三) - Socket 网络编程
- celery 、rabbitmq的exchange三种方式的实现