flex 导出Excel功能实现
方法一:
1.Excel导出主要代码:
try
{
var bytes: ByteArray = new ByteArray();
bytes.writeMultiByte(DataGridExporter.exportSCV(dataGrid),"cn-gb");
var fr:FileReference = new FileReference();
var date:Date = new Date();
var dateTime:String = date.fullYear.toString() + "年" + (Number(date.month) + 1).toString() + "月" + date.date.toString() + "日";
var excelName:String = dateTime + filename;
fr.save(bytes,excelName);
}
catch(e:Error)
{
MapUni.errorWindow(e.toString());
}
2.调用的类DataGridExporter:
public class DataGridExporter
{
public function DataGridExporter()
{
}
public static function exportSCV(dg:DataGrid,csvSeparator:String="\t",lineSeparator:String="\n"):String
{
var dataStr:String="";
var columns:Array=dg.columns;
var columnCount:int=columns.length;
var column:DataGridColumn;
var header:String="";
var headerGenerated:Boolean=false;
var dataProvider:Object=dg.dataProvider;
var rowCount:int=dataProvider.length;
var dp:Object=null;
var cursor:IViewCursor=dataProvider.createCursor();
var j:int = 0;
while(!cursor.afterLast)
{
var obj:Object=null;
obj = cursor.current;
for(var k:int = 0; k <columnCount;k++)
{
column=columns[k];
if(!column.visible)
{
continue;
}
dataStr += "\""+column.itemToLabel(obj)+"\"";
if(k<(columnCount-1))
{
dataStr+=csvSeparator;
}
if(!headerGenerated)
{
header+="\""+column.headerText+"\"";
if(k<(columnCount-1))
{
header+=csvSeparator;
}
}
}
headerGenerated=true;
if(j<(rowCount-1))
{
dataStr+=lineSeparator;
}
j++;
cursor.moveNext();
}
dataProvider=null;
columns=null;
column=null;
return (header+"\r\n"+dataStr);
}
方法二:
1.var excelFactory:SaveExcelField = new SaveExcelField();
excelFactory.ExportToExcel(dataGrid, "hendText",true);
public function ExportToExcel(dataGrid:DataGrid,filename:String, allData:Boolean):void
{
try
{
var fields:Array = new Array();
var sheet:Sheet = new Sheet();
var dataProviderCollection:ArrayCollection =dataGrid.dataProvider as ArrayCollection;
var i:int = 0;
var columns:Array = dataGrid.columns;
var rowCount:int = dataProviderCollection.length;
if(allData)
{
sheet.resize(rowCount+1,dataGrid.columnCount);
columns.pop();
}
else
{
sheet.resize(rowCount+1,dataGrid.columnCount);
/*
for (var m:int=0;m<columns.length;m++)
{
var field1:DataGridColumn=columns[m] as DataGridColumn;
//var field:DataGridColumn in columns
fields.push(field1.dataField.toString());
sheet.setCell(0,i,field1.headerText.toString());
i++;
}*/
}
//sheet.resize(rowCount+1,dataGrid.columnCount-1);
for each (var field:DataGridColumn in columns)
{
fields.push(field.dataField.toString());
sheet.setCell(0,i,field.headerText.toString());
i++;
}
for(var r:int=0;r<rowCount;r++)
{
var record:Object =dataProviderCollection.getItemAt(r);
insertRecordInSheet(r+1,sheet,record,fields);
}
var xls:ExcelFile = new ExcelFile();
xls.sheets.addItem(sheet);
var bytes: ByteArray = xls.saveToByteArray();
var fr:FileReference = new FileReference();
fr.save(bytes,filename);
}
catch(e:Error)
{
MapUni.errorWindow(e.toString());
}
}
flex 导出Excel功能实现的更多相关文章
- Atitit.导出excel功能的设计 与解决方案
Atitit.导出excel功能的设计 与解决方案 1.1. 项目起源于背景1 1.2. Js jquery方案(推荐)jquery.table2excel1 1.3. 服务器方案2 1.4. 详细 ...
- 项目笔记:导出Excel功能
1.前台这块: var ids=""; $.post("${basePath}/assets/unRegDeviceAction_getDeviceIds.do" ...
- 项目笔记:导出Excel功能分sheet页插入数据
导出Excel功能分sheet页处理数据: /*导出EXCEL*/ public void createExcel() { log.info("导出Excel功能已经启动-BEGIN&quo ...
- vue项目导出EXCEL功能
因为一些原因导出EXCEL功能必须前端来做,所以就研究了一下,在网上也找了一些文章来看,有一些不完整,我做完了就记录下来,供大家参考: 1.首先先安装依赖: npm install file-save ...
- Vue通过Blob对象实现导出Excel功能
不同的项目有不同的导出需求,有些只导出当前所显示结果页面的表格进入excel,这个时候就有很多插件,比如vue-json-excel或者是Blob.js+Export2Excel.js来实现导出Exc ...
- dataTables的导出Excel功能
Datatables它是一款基于jQuery表格插件,钟情于它操作dom的灵活.做后台的同学想必使用它能事半功倍,而且交互强.容易扩展. 我也是最近要做公司后台界面,表格涉及的很多,所以考虑使用DT, ...
- layui + mvc + ajax 导出Excel功能
为了更方便,没基础的伙伴更容易理解,我尽量详细简便 省了很多代码,一步一步的试 自己引入文件 1. html 前端视图代码 Layui的数据绑定 全部代码 @{ Layout = null; } &l ...
- asp.net core web的导入导出excel功能
这里主要记录下asp.net core web页面上进行导入导出excel的操作. 主要是导入,因为现在使用的很多前端框架(例如kendo ui)本身就有导出的功能. 这里使用到EPPlus.Core ...
- Django Admin中增加导出Excel功能
参考: https://www.cnblogs.com/yoyo008/p/9232805.html 在使用Django Admin时, 对于列表我们有时需要提供数据导出功能, 如下图: 在Djang ...
随机推荐
- codeforces mysterious present 最长上升子序列+倒序打印路径
link:http://codeforces.com/problemset/problem/4/D #include <iostream> #include <cstdio> ...
- mysql保存数据提示1366 Incorrect string value: ‘\xF0\x9F\x98\x8A\xF0\x9F…’ 解决
在保存数据时我们如果页面编辑与数据库字段编码不一样或字符集超出你了mysql数据库中的字符类型就有可能出一\\xF0\\x9F\\x98\\x8A\\xF0\\x9F提示了,下面我来简单的解决方法. ...
- Python 学习之 NumPy
NumPy(Numerical Python的简称) 是高性能科学计算和数据分析的基础包,提供了矩阵运算的功能,其一般与Scipy.matplotlib一起使用.其实,list已经提供了类似于矩阵的表 ...
- Jmeter--HTTP Cookie管理器
一.什么情况下需要用到Cookie 一般情况下对于HTTP请求的用户登入操作,需要用到Cookie来模拟用户操作,或者对一些业务只有在用户登入之后才能进行操作,比如:常见的场景有购买商品.下单.支付等 ...
- pt-find 使用实例
pt-find - Find MySQL tables and execute actions, like GNU find. 用法:pt-find [OPTION...] [DATABASE...] ...
- 使用yield关键字来提高性能
比如我们在开发当中往往会遇到这样的问题: public List<string> FindBobs(string [] names) { List<string> bobs ...
- SQL2005 : 如何在SQL Server Profiler (事件查看器)中 跟踪查看死锁恢复
SQL Profiler 通过 SQL Profiler 工具程序,可监控应用程序如何访问数据库引擎.普通来说,当系统性能需要优化或是应用程序对数据库访问的结果不合预期,都可以使用该工具确认视图问题所 ...
- python---list列表
Python 列表(List) 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内置类型 ...
- RMAN_学习笔记1_RMAN Structure概述和体系结构
2014-12-23 Created By BaoXinjian
- js 生成 yyyy-mm-dd 格式的逼格姿势
关于 js 生成 yyyy-mm-dd 格式,往往都会采取手动拼接,一般不愿意为了小功能而去动用 momentjs 之类的插件. ps: 只分享简单方法,网上有 N 多 dateformat 代码,这 ...