- 浏览: 110842 次
- 性别:
- 来自: 济南
最新评论
-
anttu:
groovy -
MeltingSnower:
基于ext的?
grails +zkoss -
mymelon:
代码能不能放出来看看啊。
grails +zkoss -
dellsoft:
用的csc365kl 写道请问你的控制层是怎么处理的 是用的g ...
grails +zkoss -
csc365kl:
请问你的控制层是怎么处理的 是用的grails的 还是 zk的 ...
grails +zkoss
用 poi 来导出 excel 文件
在你的 domaincontroller 中加入
这个好处就是导出的表头信息通过 properties来获取!
import org.codehaus.groovy.grails.commons.* import org.apache.poi.hssf.usermodel.HSSFWorkbook import org.apache.poi.hssf.usermodel.HSSFSheet import org.apache.poi.hssf.usermodel.HSSFRow import org.apache.poi.hssf.usermodel.HSSFCell import org.codehaus.groovy.grails.commons.GrailsDomainClass import org.codehaus.groovy.grails.web.converters.ConverterUtil import org.springframework.web.servlet.support.RequestContextUtils as RCU import org.codehaus.groovy.grails.scaffolding.DomainClassPropertyComparator; import org.springframework.context.MessageSource import org.apache.poi.hssf.usermodel.HSSFCellStyle import org.apache.poi.hssf.usermodel.HSSFFont import org.apache.poi.hssf.util.HSSFColor; class XlsExportService { // def messageSource MessageSource messageSource boolean transactional = true // def config = ConfigurationHolder.config // def domainName def xlsExport(out, request, domain, datas) { def excludedProps = ['id', 'version'] def column = [] def titles = [] def outProperties def locale = RCU.getLocale(request) // def text def args def domainName = domain.toLowerCase() GrailsDomainClass domainClass = ConverterUtil.getDomainClass(domain) if (domainClass != null) { outProperties = domainClass.properties.findAll {!excludedProps.contains(it.name)} } Collections.sort(outProperties, new DomainClassPropertyComparator(domainClass)) outProperties.each { column << "${it.name}" def text = messageSource.getMessage( "${domainName}.${it.name}".toString(), args == null ? null : args.toArray(), "${domainName}.${it.name}".toString(), locale) titles << text } HSSFWorkbook wb = new HSSFWorkbook(); HSSFSheet sheet = wb.createSheet("new sheet"); HSSFRow row HSSFCell cell HSSFCellStyle style = wb.createCellStyle() HSSFFont font = wb.createFont() font.setFontHeightInPoints((short)12) font.setFontName("宋体") font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD) style.setFont(font) style.setAlignment(HSSFCellStyle.ALIGN_CENTER) style.setFillBackgroundColor(HSSFColor.ORANGE.index) // style.setFillPattern(HSSFCellStyle.) // set the title row = sheet.createRow((short) 0); titles.eachWithIndex {title, i -> cell = row.createCell((short) (i)); cell.setCellStyle(style) cell.setCellValue(title); } // set the data datas.eachWithIndex {data, i -> row = sheet.createRow((short) (i+1)); column.eachWithIndex {p, j -> row.createCell((short) (j)).setCellValue(data."${p}"); } } // Write the output to a file wb.write(out); out.close() } }
在你的 domaincontroller 中加入
def exportXls = { // def excludedProps = ['id', 'version'] // def column = [] // def titles = [] // def outProperties = [] // GrailsDomainClass domainClass = ConverterUtil.getDomainClass("Person"); // if (domainClass != null) { // domainClass.persistentProperties.each {p -> // outProperties << p.name // }; // // } // outProperties.each { // column << "${it}" // titles << message(code: "person.${it}") // } response.setHeader("Content-disposition", "attachment; filename=person.xls") response.setContentType("application/vnd.ms-excel") // ServletOutputStream f = response.getOutputStream(); xlsExportService.xlsExport(response.outputStream, request,"Person", Person.list()) // render(contextType:"application/vnd.ms-excel") }
这个好处就是导出的表头信息通过 properties来获取!
评论
4 楼
kapok_fly
2009-12-02
有个export plugin你可以try一下, 不过不能针对大数据量进行export.
可以自己改写.
可以自己改写.
3 楼
leon1509
2009-05-13
导出的只有title,没有数据啊?
2 楼
dellsoft
2008-07-14
你确认在你的controller中定义这个XlsExportService 吗
XlsExportService xlsExportService
XlsExportService xlsExportService
1 楼
ourfirebird
2008-07-13
不能执行:java.lang.NullPointerException: Cannot invoke method xlsExport() on null object
在controller中调用 xlsExportService.xlsExport(response.outputStream, request,"Person", Person.list())时,request参数如何赋值?
在controller中调用 xlsExportService.xlsExport(response.outputStream, request,"Person", Person.list())时,request参数如何赋值?
发表评论
-
Rescheduling a Quartz job programatically
2012-02-14 11:34 0In our current project we fa ... -
1.4M
2011-06-23 20:44 8161.4 版本后,如果用代理上网,需要设置代理,才能让grail ... -
groovy Ip地址表达式
2011-04-28 18:55 1565 -
change the default locale
2011-04-13 19:37 952... -
groovy
2010-08-09 14:40 1158def urls = ["ip1" ... -
grails + jquery grid plugin
2010-03-14 09:52 1511Jquery Grid Json 格式方法 http ... -
grails +zkoss 开发总结
2010-03-14 09:42 1509zk component develop 一、)jav ... -
grails 开发总结
2010-03-14 09:40 1586在使用grails 开发的过程,一些总结,随笔 ... -
grails +zkoss
2010-01-09 16:58 1270基于grails+zkoss应用 1)登录窗口 2)主 ... -
grails 跟踪 sql
2009-05-14 15:53 1027http://www.piragua.com/2009/06/ ... -
grails assgined the id
2009-05-09 22:29 1239使用hibernate 的自定义主键 impor ... -
grails 原始sql
2009-05-09 22:13 1228import groovy.sql.Sql; c ... -
hibernate custom generator
2009-05-09 20:54 1023public class CustomIdSequenceGe ... -
grails 1.1 Gorm 部分新特性提前知道
2008-10-30 17:21 1807说明:grails 1.1部分新特性,我只是看 grails ... -
grailsflow
2008-10-30 16:43 2414grailsflow 具体地址 http:/ ... -
grails 根据数据库自动生产 domains
2008-07-04 17:25 2896GenerateDataabase.groovy impo ... -
grails war 包定制
2008-07-04 17:18 1463在config.groovy 下面配置 grails.war ... -
grails datasource 中配置数据源用户名称和密码 加密
2008-07-04 17:16 2430在datasource.groovy password = Y ... -
grails 自定义 validator
2008-07-04 17:05 1125http://www.zorched.net/2008/01/ ... -
grails services transaction
2008-07-02 15:26 1611在 graisl 应用中,默认情况下,services 的事务 ...
相关推荐
grails导出csv的实例代码,里面该有的资源都有,需要重新组装下才能使用。
Grails Grails Grails Grails Grails
Grails权威指南Grails权威指南Grails权威指南Grails权威指南Grails权威指南Grails权威指南
Grails 导出插件 原始导出插件的主要分支。 来源从 SVN 分叉并在此处维护。
Grails项目的应用越来越多,而对于初学者来说,在Eclipse下搭建Grails项目是一个难题,这个文档将教会你如何搭建Grails项目,希望对你有所帮助。
Grails入门指南中文pdf -- 针对grails1.0.4更新,附加idea8 开发grails的流程
Grails1.1中文文档
grails+Xfire webservice
在学习任何东西之前,最重要的是培养兴趣,Groovy世界最耀眼的技术之一--Grails相信大家早已耳闻,我将通过Grails实战系列文章 向您展现Grails的迷人风采,使您感受到Grails的魅力,以至疯狂地爱上Grails,并坠入...
grails-2.1.zip.001
详细讲解grails开发环境配置。 详细讲解grails连接mysql数据库,crud开发
Grails专为下一代JavaWeb应用程序而设计的框架,其借助于Groovy动态语言,使Web开发变得简单而方便。Grails尽量为更多现有的Java项目创建一个全面的框架(不仅局限于视图处理),这和当前一些Java框架提供给用户的一...
Grails 中文 参考手册
grails grails入门经典 grails入门 grails例子 grails资料 通过自学一点点积累起来的,相信对你有帮助的。
Grails 1.3.7英文版官方参考手册,学习Grails的权威指南
grails3.2.8 part1
grails 中文文档+grails-fckeditor-0.9.5.zip插件
grails的插件系统也是其亮点之一。首先,和rails,django等web框架类似,基于微内核的思想,插件(可重用模块)是框架的一等公民。grails除了核心模块以外的功能几乎都是通过插件方式实现的。实际上,一个grails插件...
grails-2.3.6