Skip to content

rgettman/jett

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

93 Commits
 
 
 
 
 
 
 
 

Repository files navigation

JETT - Java Excel Template Translator
----------------

JETT can be found online at http://jett.sourceforge.net.

Description
----------------

JETT is Java Excel Template Translator.  Give it a Map of "beans" -- mapping
variable names to your own data objects, specify a pre-existing Excel template
file, and JETT will create a new Excel spreadsheet, populating your data into
it.  The data can come from any source.  Mark up your template spreadsheet
first, with JEXL Expressions (e.g. "${myVariable}") and XML-like Tags (e.g.
<jt:forEach items="${myList}" var="item">) for control over how JETT translates
your template spreadsheet and populates your data.  You can even create your
own Tags to implement custom processing logic.  JETT works with .xls and .xlsx
Excel files.

Example
----------------

Here is a quick example of how to use JETT:

- Excel template spreadsheet:

+----------------+----------------+
|${var}          |${var2}!        |
+----------------+----------------+

- Java code to use JETT:

Map<String, Object> beans = new HashMap<String, Object>();
beans.put("var", "Hello");
beans.put("var2", "World");
ExcelTransformer transformer = new ExcelTransformer();
try
{
   transformer.transform("template.xlsx", "result.xlsx", beans);
}
catch (IOException e)
{
   System.err.println("I/O error occurred: " + e.getMessage());
}
catch (InvalidFormatException e)
{
   System.err.println("Spreadsheet was in invalid format: " + e.getMessage());
}

- The resultant Excel spreadsheet:

+----------------+----------------+
|Hello           |World!          |
+----------------+----------------+

Installation
----------------

To use JETT, you may download the latest distribution from
http://sourceforge.net/projects/jett/files/.  The only module is "jett-core".
Place the "jett-core" jar library in your classpath.

See "Dependencies" below for the list of dependencies.

If you are using Maven 2+, then you may place the following dependency in your
pom.xml.  Since 0.3.0, JETT has been available in the Maven 2 Central
Repository.

<dependency>
    <groupId>net.sf.jett</groupId>
    <artifactId>jett-core</artifactId>
    <version>0.11.0</version>
</dependency>

Dependencies
----------------

JETT can be used with Java 1.7+.  JETT depends on several external libraries:

The following libraries are required, as they are used by JETT:
- Apache POI 3.14 (http://poi.apache.org/download.html) (or higher)
   - poi-3.14-20160307.jar
   - poi-ooxml-3.14-20160307.jar
   - poi-ooxml-schemas-3.14-20160307.jar
   - Apache POI, in turn, depends on the following library: XML Beans 2.6.0.
- XML Beans 2.6.0
   - xmlbeans-2.6.0.jar (Comes with Apache POI distribution)
- Apache Commons JEXL 2.1.1 (http://commons.apache.org/jexl/download_jexl.cgi)
   - commons-jexl-2.1.1.jar
   - Apache Commons JEXL 2.1.1 in turn depends on Commons Logging 1.1.1.
- Apache Commons Logging 1.2 (http://commons.apache.org/logging/download_logging.cgi)
   - commons-logging-1.2.jar
- SourceForge's jAgg 0.9.0 (http://sourceforge.net/projects/jagg/files/) (or higher)
   - jagg-core-0.9.0.jar
   - Full disclosure: I built jAgg also.
- JUnit 4.8.2 (for testing only)
   - junit-4.8.2.jar
- HSQLDB 1.8.0.10 (for testing only)
   - hsqldb-1.8.0.10.jar
- Apache Log4j2 (https://logging.apache.org/log4j/2.x/download.html) (or higher)
   - log4j-api-2.9.0.jar
   - log4j-core-2.9.0.jar
   - log4j-jcl-2.9.0.jar (So JEXL's Commons Logging goes through Log4j2)

Build Instructions
----------------

If you would like to build JETT yourself, do the following:
1. Get the source code.
  a. Download the JETT latest distribution from
     http://sourceforge.net/projects/jett/files/.
     This contains the source code from the latest release.
  OR
  b. Checkout the latest source code from the trunk using Subversion using the
     Subversion URL http://svn.code.sf.net/p/jett/code-0/trunk.

2. Get Maven 2 or higher from http://maven.apache.org/ and install it.

3. Run Maven to build JETT.
   mvn clean install

Contacts
----------------

For issues, bugs, suggestions, and feature requests, please send an email to
the "jett-users" mailing list: jett-users@lists.sourceforge.net.

Licensing
----------------

JETT is licensed under the "GNU Lesser General Public License Version 3" at
http://www.gnu.org/copyleft/lesser.html.

Author
----------------

My name is Randy Gettman.  For a while I used jXLS for translating Excel
template spreadsheets using Java.  At the time, jXLS suffered from poor
performance when supplying lots of data.  I was inspired to create JETT after
this experience so that I could create spreadsheets from templates quickly, and
with some features that jXLS didn't have.  By the time I released JETT, jXLS
had fixed a few performance issues, so they perform similarly.  However, JETT
has a number of features that jXLS doesn't have (jXLS has a few features that
JETT doesn't (yet) have.)  The bottom line is that I wanted a jXLS with more
features, and JETT is the result.

About

JETT - Java Excel Template Translator

Resources

Stars

Watchers

Forks

Packages

No packages published