导出DataGrid数据为excel文件传输格式

rabbit_zizhu 2010-11-18 09:30:01
现在需要将DataGrid的数据导出为Excel文件。
现在的处理方式是将DataGrid中的数据全部封装成一个String。
到servlet端进行解析。

但是这样存在的一个问题是:如果数据量过大,效率会不会受到影响。而且封装成一个String,需要特殊字符进来分行。但是这个特殊字符有可能会在数据中也出现,这样就存在很大的隐患。

请问大家都用什么方式将要导出的数据从flex端传到servlet呢。
...全文
194 12 打赏 收藏 举报
写回复
12 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
rabbit_zizhu 2010-12-23
还是没有等到满意的答案。

不知道有没有人试过前台用ArrayCollection和后台List进行转换来传递数据?
  • 打赏
  • 举报
回复
rabbit_zizhu 2010-12-23
[Quote=引用 10 楼 curbstone119 的回复:]

???
你Flex的数据是从哪来的??
如果是后台,那直接用后台的数据生成excel不就行了??
[/Quote]

不是后台返回的数据,就能直接用的,需要前台处理一下的。
  • 打赏
  • 举报
回复
curbstone119 2010-12-09
???
你Flex的数据是从哪来的??
如果是后台,那直接用后台的数据生成excel不就行了??
  • 打赏
  • 举报
回复
comitea 2010-12-08
數據綁定到XML,再轉存為.xls
  • 打赏
  • 举报
回复
蓝色_冰点 2010-12-07
我自己封装了个,直接导出电子表格的xml格式,不经过服务器
应该不是你想要的那种
  • 打赏
  • 举报
回复
rabbit_zizhu 2010-12-07
看来又要无满意答案结贴了。最后顶一下。
  • 打赏
  • 举报
回复
rabbit_zizhu 2010-12-03
还没有看到想要的答案。继续顶!
  • 打赏
  • 举报
回复
ecoders 2010-11-22
转成CSV,放到粘贴板就可以了。多大的数据量都不怕,和服务器没有关系
System.setClipboard("" + DataGridDataExporter.exportCSV(dg1));

转csv的代码如下

package com.utils
{
import mx.controls.DataGrid;
import mx.controls.dataGridClasses.DataGridColumn;
import mx.collections.ArrayCollection;
import mx.collections.XMLListCollection;
import mx.collections.IList;
import mx.collections.IViewCursor;
import mx.collections.CursorBookmark;
public class DataGridDataExporter
{
public static function exportCSV(dg:DataGrid, csvSeparator:String="\t", lineSeparator:String="\n"):String
{
var data: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;

//loop through rows
while (!cursor.afterLast)
{
var obj:Object = null;
obj = cursor.current;

//loop through all columns for the row
for(var k:int = 0; k < columnCount; k++)
{
column = columns[k];
//Exclude column data which is invisible (hidden)
if(!column.visible)
{
continue;
}

data += "\""+ column.itemToLabel(obj)+ "\"";
if(k < (columnCount -1))
{
data += csvSeparator;
}
//generate header of CSV, only if it's not genereted yet
if (!headerGenerated)
{
header += "\"" + column.headerText + "\"";
if (k < columnCount - 1)
{
header += csvSeparator;
}
}


}

headerGenerated = true;
if (j < (rowCount - 1))
{
data += lineSeparator;
}
j++;
cursor.moveNext ();
}

//set references to null:
dataProvider = null;
columns = null;
column = null;

return (header + "\r\n" + data);
}
}
}
  • 打赏
  • 举报
回复
rabbit_zizhu 2010-11-20
继续顶!希望高人给出更好的方法
  • 打赏
  • 举报
回复
rabbit_zizhu 2010-11-19
怎么沉了啊。继续顶!
  • 打赏
  • 举报
回复
水中影子 2010-11-19
可以把数据封装成html

数据量大,依然不好,可以考虑用后台POI或JXL类似的工具
  • 打赏
  • 举报
回复
kellerxq 2010-11-18

public function loadDGInExcel(dg:DataGrid, url:String):void
{
var request:URLRequest=new URLRequest("./servlet/expexcel");
request.contentType='application/msexcel';
request.data=convertDGToHTMLTable(dg);
request.method=URLRequestMethod.POST;
navigateToURL(request, "_self");
}

convertDGToHTMLTable处理过程中将特殊符号半角转全角如:'<'转为“〈”
  • 打赏
  • 举报
回复
发帖
Flex

4328

社区成员

多媒体/设计 Flex
社区管理员
  • Flex
加入社区
帖子事件
创建了帖子
2010-11-18 09:30
社区公告
暂无公告