Excel module
The Excel module allows you to render Excel document. It is rather simple to use as it only requires to import a static file.
The tool uses the jxls library.
In order to use the Excel module, you need to create an Excel based template – see http://jxls.sourceforge.net for details instruction.
What’s New in v1.2.1
- Transparent async rendering
- define "excel.async=true' in application.conf file or do renderArgs.set(RenderExcel.RA_ASYNC, true) to enable asynchronous Excel generation
What’s New in v1.2
- Update with Play!Framework v1.2
- Transparent Excel Render
- now not need to bother with renderExcel, instead use Controller.render(...) or Controller.renderTemplate(...) as usual. Excel plugin will handle Excel rendering if request.format is ‘xls’ or ‘xlsx’ automatically
- API changes
- renderExcel() call removed
- previously use “fileName” renderArg to denote filename of the Excel file generated, now please use RenderExcel.RA_FILENAME instead
What’s New in v1.0a
- support Play 1.1-RC1
- jxls update to 1.0-RC1 along with it’s dependencies
- POI 3.6
- Jexl 2.0
Enable the Excel module for the application
In the /conf/application.conf file, enable the Excel module by adding this line:
# The Excel module
module.Excel=${play.path}/modules/Excel
excel.template.root=app/views
note, please change the excel.template.root from app/views to some where else when you use excel module with Play version 1.02 or before. Otherwise your application will not be able to startup on product mode.
Using the Excel module
The renderExcel() method (only apply for versions before v1.2):
import static play.modules.excel.Excel.*;
And then use the renderExcel() method as you would use the render() method.
The renderExcel() behavior is almost the same as that of render() except the following differences:
- the template should be an excel file with “.xls” suffix rather than a text file with ".html"
- You can use renderArgs.put(“fileName”, “your-file.xls”) to indicate the name of the excel file to be generated
Set request.format New in v1.2
Set request.format to ‘xls’ or ‘xlsx’ to render user Excel template. The excel template should be put in the same dir as normal html template, the file suffix shall comply with request.format setting. An easy way to set request.format is via route configuration. Please refer to http://www.playframework.org/documentation/1.2.1/routes#content-types for detail
Please refer to the sample for an example.