ru.curs.xylophone.XLSReportWriter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xylophone Show documentation
Show all versions of xylophone Show documentation
xylophone - LGPL Java library
/*
(с) 2016 ООО "КУРС-ИТ"
Этот файл — часть КУРС:Xylophone.
КУРС:Xylophone — свободная программа: вы можете перераспространять ее и/или изменять
ее на условиях Стандартной общественной лицензии ограниченного применения GNU (LGPL)
в том виде, в каком она была опубликована Фондом свободного программного обеспечения; либо
версии 3 лицензии, либо (по вашему выбору) любой более поздней версии.
Эта программа распространяется в надежде, что она будет полезной,
но БЕЗО ВСЯКИХ ГАРАНТИЙ; даже без неявной гарантии ТОВАРНОГО ВИДА
или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЕННЫХ ЦЕЛЕЙ. Подробнее см. в Стандартной
общественной лицензии GNU.
Вы должны были получить копию Стандартной общественной лицензии ограниченного
применения GNU (LGPL) вместе с этой программой. Если это не так,
см. http://www.gnu.org/licenses/.
Copyright 2016, COURSE-IT Ltd.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with this program. If not, see http://www.gnu.org/licenses/.
*/
package ru.curs.xylophone;
import org.apache.poi.hssf.usermodel.HSSFFormulaEvaluator;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
import java.io.IOException;
import java.io.InputStream;
/**
* Реализация ReportWriter для вывода в формат MSOffice 97-2003 (XLS).
*/
final class XLSReportWriter extends POIReportWriter {
private HSSFWorkbook wb;
XLSReportWriter(InputStream template, InputStream templateCopy)
throws XML2SpreadSheetError {
super(template, templateCopy);
}
@Override
Workbook createResultWb(InputStream templateCopy)
throws InvalidFormatException, IOException {
if (templateCopy == null) {
wb = new HSSFWorkbook();
} else {
wb = (HSSFWorkbook) WorkbookFactory.create(templateCopy);
//Remove all merged regions -- not to mess with copied templates
for (int i = 0; i < wb.getNumberOfSheets(); i++) {
HSSFSheet ws = wb.getSheetAt(0);
for (int j = ws.getNumMergedRegions() - 1; j >= 0; j--) {
ws.removeMergedRegion(j);
}
}
}
return wb;
}
@Override
void evaluate() {
HSSFFormulaEvaluator.evaluateAllFormulaCells(wb);
}
}