data:image/s3,"s3://crabby-images/c7220/c7220677cdf8cf2e00999c6cbf44a86fc5775fec" alt=""
Agenda
- How to avoid Excel generation
- The current approach using Apache POI
- Live demo of writing Excel with Spreadsheet Builder
- Tabular data
- Advanced tabular data
- Writing advanced Excel files with Spreadsheet Builder
- Non-tabular reports
- Reading Excel files with Spreadsheet Criteria
data:image/s3,"s3://crabby-images/95b7b/95b7b5749b7d5a5026289e586179b22861453116" alt=""
Example Data - Twitter
data:image/s3,"s3://crabby-images/3b812/3b81276ae05ba2987f4892701a379a22f4f13f73" alt=""
data:image/s3,"s3://crabby-images/1a869/1a869699b4dcd2801559e89756d37fac061707ae" alt=""
Unbeatable Excel
data:image/s3,"s3://crabby-images/f36b0/f36b084626df93a7200d3e218dc33bb7965dec37" alt=""
Unbeatable Excel
data:image/s3,"s3://crabby-images/4988f/4988f425d432f54e0ab8e2ef1a8eefb99d788d3f" alt=""
CSV Workaround
data:image/s3,"s3://crabby-images/e7b65/e7b65b4583f08743e7c3c9e6f32395c66128265e" alt=""
TAB Separated File Workaround
data:image/s3,"s3://crabby-images/7352b/7352ba54a25b403fc5f99485aab62bc7c2350ede" alt=""
HTML Workaround
data:image/s3,"s3://crabby-images/193fc/193fc3a60a82135f7203c3af3d09c128ffec146d" alt=""
Apache POI
data:image/s3,"s3://crabby-images/9434f/9434fc59b87704902ea10ef04caffac79e1c3bc1" alt=""
Apache POI (cont.)
data:image/s3,"s3://crabby-images/0a7f9/0a7f905c8b8420c7242ce1756a8d89259503cd2a" alt=""
Apache POI (cont.)
Apache POI Export
XSSFWorkbook workbook = new XSSFWorkbook()
XSSFSheet sheet = workbook.createSheet('Tweets')
XSSFRow headerRow = sheet.createRow(0)
['User', 'Favourites', 'Retweets','Text'].eachWithIndex { header, i ->
XSSFCell headerCell = headerRow.createCell(i)
headerCell.cellValue = header
}
tweets.eachWithIndex { Status tweet, int i ->
XSSFRow row = sheet.createRow(i + 1)
XSSFCell screenNameCell = row.createCell(0)
screenNameCell.cellValue = tweet.user.screenName
XSSFCell favouriteCountCell = row.createCell(1)
favouriteCountCell.cellValue = tweet.favoriteCount
XSSFCell retweetCountCell = row.createCell(2)
retweetCountCell.cellValue = tweet.retweetCount
XSSFCell textCell = row.createCell(3)
textCell.cellValue = tweet.text
}
workbook.write(out)
Tabular Data
Headlines and status per each row
Spreadsheet Builder
SpreadsheetBuilder builder = PoiSpreadsheetBuilder.create(out)
builder.build {
sheet 'Tweets', {
row {
cell 'User'
cell 'Favourites'
cell 'Retweets'
cell 'Text'
}
tweets.each { tweet ->
row {
cell tweet.user.screenName
cell tweet.favoriteCount
cell tweet.retweetCount
cell tweet.text
}
}
}
}
Tabular Data
data:image/s3,"s3://crabby-images/e5b3a/e5b3a77978117af643de71f9eb804e2f21a7681e" alt=""
Advanced
Tabular Data
Bold headlines with filter and scroll freeze, status per each row, some data highlighted
Filters and Scroll Lock
builder.build {
// ...
sheet 'Tweets', {
filter auto
freeze 0, 1
row {
// ...
}
// ...
}
}
Styles
builder.build {
style 'headline', {
font {
style bold
}
}
style 'text', {
wrap text
align center, justify
}
style 'highlighted', {
foreground orange
}
sheet 'Tweets', {
// ...
row {
style 'headline'
// ...
}
}
}
Advanced Tabular Data
data:image/s3,"s3://crabby-images/cb1b6/cb1b69e4b03fcd01d5f1639af72564d51f4ca89f" alt=""
Unit Testing
criteria.query {
sheet {
row {
cell {
style {
font {
style bold
}
}
}
}
}
}.size() == 5
criteria.query {
sheet {
row {
cell {
style {
foreground orange
}
}
}
}
}.rows.size() == 1
criteria.query {
sheet {
row {
cell {
value 'yes'
}
}
}
}.size() == 73
Excel Report
Non-tabular structure, different text styles, borders, print setup
Spans
// | A | B | C |
// -----------------------------------------
// 1 | Name | Text | Fav. Count |
// ---- - - -
// 2 | Name | Text | Fav. Count |
// --------------- ----------------
// 3 | Handle | Text | Rtw. Count |
// --------------- - -
// 4 | Create | Text | Rtw. Count |
// -----------------------------------------
Spans
sorted.each { tweet ->
row {
cell {
value tweet.user.name
rowspan 2
}
cell {
value tweet.text
rowspan 4
}
cell {
value tweet.retweetCount
rowspan 2
}
}
row()
row {
cell { value "@$tweet.user.screenName" }
cell('C') {
value tweet.favoriteCount
rowspan 2
}
}
row { cell { value tweet.createdAt } }
}
Dimensions
sorted.each { tweet ->
row {
cell {
value tweet.user.name
width 4 cm
}
cell {
value tweet.text
width 14 cm
}
cell {
value tweet.retweetCount
width 2 cm
}
}
row()
row {
cell { value "@$tweet.user.screenName" }
cell('C') { value tweet.favoriteCount }
}
row {
cell { value tweet.createdAt }
}
}
Page
sheet('Tweets') {
page {
paper a4
orientation portrait
}
}
Date
style 'date', {
format 'dd.mm.yyyy hh:mm'
}
Borders
style 'border-top', {
border top, {
style thick
color black
}
}
style 'border-bottom', {
border bottom, {
style thick
color black
}
}
style 'border-left', {
border left, {
style thick
color black
}
}
style 'border-right', {
border right, {
style thick
color black
}
}
Excel Report
data:image/s3,"s3://crabby-images/c23d3/c23d3162b94cc6cd32bb8f5078e9b3b4328ffc9a" alt=""
Reading Excel
Reading Order
data:image/s3,"s3://crabby-images/59bb1/59bb176413abca492f32a52541648a43b841a5b9" alt=""
Reading Order (cont.)
data:image/s3,"s3://crabby-images/59bb1/59bb176413abca492f32a52541648a43b841a5b9" alt=""
Cell productCell = criteria.query {
sheet {
row {
cell {
value 'Product'
style { font { style bold } }
}
}
}
}.cell
Cell quantityCell = criteria.query {
sheet {
row {
cell {
value 'Qty'
style { font { style bold } }
}
}
}
}.cell
Cell totalRow = criteria.query {
sheet {
row {
cell('A') {
value 'Total'
style { font { style bold } }
}
}
}
}.row
Spreadsheet Criteria
Spreadsheet Criteria
Map<String, Integer> quantities = [:]
Cell productNameLineCell = productCell.bellow
Cell quantityLineCell = quantityCell.bellow
while (productNameLineCell && productNameLineCell.row.number < totalRow.number) {
quantities[productNameLineCell.read(String)] = quantityLineCell.read(Number).intValue()
productNameLineCell = productNameLineCell.bellow
quantityLineCell = quantityLineCell.bellow
}
data:image/s3,"s3://crabby-images/81ca0/81ca01a8e263f8496584f14c688ecf00e691509c" alt=""
The End?
data:image/s3,"s3://crabby-images/4f39d/4f39d51adf78c9170a3b9c854def069f24e4eb90" alt=""
More Features?
data:image/s3,"s3://crabby-images/803ee/803eea8d431f5f3aba5263318f0f64c542f73a5d" alt=""
More Features!
data:image/s3,"s3://crabby-images/a89eb/a89ebf2290f2c600ec6faa3c90ad55b0f20bdd60" alt=""
Grouping
data:image/s3,"s3://crabby-images/2b575/2b575a4fbf7ec5dac44d94b7bb1af2acc83859d9" alt=""
Sheet Protection
data:image/s3,"s3://crabby-images/b8d9a/b8d9aec4e33fb74075dbab9dc25074a20a264b09" alt=""
Pictures
data:image/s3,"s3://crabby-images/d5cbc/d5cbcdb41c00ebbfb6a5cd9d3fb329713d0cec7b" alt=""
Comments
data:image/s3,"s3://crabby-images/788d2/788d2bbea2671b1e5fa2f30545aa7168a93a664a" alt=""
Named Cells & Formulas
data:image/s3,"s3://crabby-images/9159b/9159b6ad10f7bfd502baf1e6ccba73ab9ac40f6e" alt=""
Borders
data:image/s3,"s3://crabby-images/af26c/af26cabe1d9f2b557436f90979be4e415b4a35e3" alt=""
Rich Text
data:image/s3,"s3://crabby-images/6efc9/6efc9947969d93b5651b7e28b6a25ae6316fa6a8" alt=""
Text Rotation
data:image/s3,"s3://crabby-images/17f74/17f744d9378d179baffdee2843c3d75cb9c2da23" alt=""
Excel in Groovy
By musketyr
Excel in Groovy
- 3,683