- 浏览: 114531 次
- 性别:
- 来自: 济南
-
最新评论
-
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 8751.4 版本后,如果用代理上网,需要设置代理,才能让grail ... -
groovy Ip地址表达式
2011-04-28 18:55 1631 -
change the default locale
2011-04-13 19:37 1005... -
groovy
2010-08-09 14:40 1225def urls = ["ip1" ... -
grails + jquery grid plugin
2010-03-14 09:52 1570Jquery Grid Json 格式方法 http ... -
grails +zkoss 开发总结
2010-03-14 09:42 1596zk component develop 一、)jav ... -
grails 开发总结
2010-03-14 09:40 1636在使用grails 开发的过程,一些总结,随笔 ... -
grails +zkoss
2010-01-09 16:58 1341基于grails+zkoss应用 1)登录窗口 2)主 ... -
grails 跟踪 sql
2009-05-14 15:53 1074http://www.piragua.com/2009/06/ ... -
grails assgined the id
2009-05-09 22:29 1288使用hibernate 的自定义主键 impor ... -
grails 原始sql
2009-05-09 22:13 1281import groovy.sql.Sql; c ... -
hibernate custom generator
2009-05-09 20:54 1095public class CustomIdSequenceGe ... -
grails 1.1 Gorm 部分新特性提前知道
2008-10-30 17:21 1876说明:grails 1.1部分新特性,我只是看 grails ... -
grailsflow
2008-10-30 16:43 2472grailsflow 具体地址 http:/ ... -
grails 根据数据库自动生产 domains
2008-07-04 17:25 2997GenerateDataabase.groovy impo ... -
grails war 包定制
2008-07-04 17:18 1517在config.groovy 下面配置 grails.war ... -
grails datasource 中配置数据源用户名称和密码 加密
2008-07-04 17:16 2479在datasource.groovy password = Y ... -
grails 自定义 validator
2008-07-04 17:05 1175http://www.zorched.net/2008/01/ ... -
grails services transaction
2008-07-02 15:26 1660在 graisl 应用中,默认情况下,services 的事务 ...
相关推荐
Grails 出口插件是针对 Grails 框架的一个实用工具,主要用于方便地将数据导出到各种常见的文件格式,如 CSV、Excel 或 PDF。这个插件源自 SVN 仓库的一个原始版本,并在后续的发展中被分叉出来进行独立维护和更新,...
JasperReports是一个开源的Java报告工具,具有灵活的报告布局,支持多种数据供应方式,并能导出多种格式的报告,包括纯文本、Excel、PDF、RTF、HTML、XML和CSV。JasperReports的版本为0.9.5,使用.jrxml或.jrxml文件...
将交易搜索结果或所有交易导出到Excel要求Java 7或8运行应用程序克隆存储库,然后重命名示例DataSource.groovy文件。 git clone ...
scratch少儿编程逻辑思维游戏源码-减压游戏.zip
少儿编程scratch项目源代码文件案例素材-英勇之鸟.zip
少儿编程scratch项目源代码文件案例素材-羊羊繁殖V2.5.zip
scratch少儿编程逻辑思维游戏源码-加特林混战 多人游戏.zip
少儿编程scratch项目源代码文件案例素材-西装英雄.zip
在使用 R 语言进行科研绘图时,颜色的选择是一件让人特别纠结的事情。本系列文章介绍了 R 语言科研绘图时常用的一些配色。本资源给大家提供了文章对应的 PPT。
scratch少儿编程逻辑思维游戏源码-海洋战争.zip
少儿编程scratch项目源代码文件案例素材-万圣夜惊魂.zip
HarmonyOS安全开发赋能,含有HarmonyOS多个场景的安全策略赋能
平台的服务端和客户端源码 整理出来的的游戏源码
scratch少儿编程逻辑思维游戏源码-街头霸王.zip
少儿编程scratch项目源代码文件案例素材-小船.zip
scratch少儿编程逻辑思维游戏源码-几何冲刺(4).zip
少儿编程scratch项目源代码文件案例素材-消灭病毒大作战.zip
scratch少儿编程逻辑思维游戏源码-功夫猫.zip
scratch少儿编程逻辑思维游戏源码-节奏积木 马里奥.zip
scratch少儿编程逻辑思维游戏源码-可爱的超级马里奥.zip