乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > 前台extjs,后台java,导出 gridpanel的数据...-extjs导出excel,extjsgrid导出ex

前台extjs,后台java,导出 gridpanel的数据...-extjs导出excel,extjsgrid导出ex

作者:乔山办公网日期:

返回目录:excel表格制作


通常要导出的数据是都与后台数据库交互查询出来copy的。
比如说我在页面通过数据集显示出某班学生成绩的信息,数据集要获取数据就必须查询,查询过程就和数据库交互了。

把数据从后台查出,放到页面,再从页面重新收集相同的数据导出.....这样的话,从根本上来说,还是离不开后台(没做过这种操作,也不知道能不能实现,不过感觉后台既然查出数据了,直接在xxxAction调用方法把它导出了还简洁点)。

导出excel我做过,如果楼主要相关代码,我可以给你


在你导出的方法里面获得start,limit 如果不为空的话就导出当前页的数据,如果为空就导出全部信息
导出搜索出来的数据把根据查询的字段传过去再查一遍导出就行了,想有选择性的导出数据就看你这个数据是不是有规律,或者是不是根据查询条件而查出来的,或者可以在后台获取List

前台
new Ext.Button({
text:'导出EXCEL',
handler:function(){
var appWindow = window.open("getExecl.do"); //调action得到数据生成execl格式的7a64e58685e5aeb9337数据,response发往前台
appWindow.focus();
}
})

后台: filename是导出的文件名,heads是excel表头,datalist是数据
public void createExcelStream(HttpServletResponse response,String filename,String[] heads,List<String[]> datalist){
try{
OutputStream os = response.getOutputStream();
WritableWorkbook wbook = Workbook.createWorkbook(os);
WritableSheet wsheet = wbook.createSheet(filename, 0);
for(int i=0 ; i<heads.length ; i++) {
Label label =new Label(i,0 ,heads[i]);
wsheet.addCell(label);
}
for(int i=0 ;i<datalist.size();i++) {
for(int j=0 ; j<datalist.get(i).length ; j++){
Label label =new Label(j,i+1 ,datalist.get(i)[j]);
wsheet.addCell(label);
}
}
response.setHeader("Content-disposition","attachment;" +
"filename="+ new String(filename.getBytes("GBK"), "ISO_8859_1") +".xls");
response.setContentType("application/vnd.ms-excel");
wbook.write();
wbook.close();
os.close();
}catch(Exception e){
e.printStackTrace();
}
} }

相关阅读

关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网