All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.brsanthu.dataexporter.DataExporter Maven / Gradle / Ivy

Go to download

data-exporter is a Java library to export the tabular data (like List of rows) into many output formats. As of latest release, this library supports following formats.

The newest version!
/*
 * #%L
 * data-exporter
 * %%
 * Copyright (C) 2012 - 2013 http://www.brsanthu.com
 * %%
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */
package com.brsanthu.dataexporter;


import java.io.PrintWriter;
import java.util.Arrays;
import java.util.List;

import com.brsanthu.dataexporter.model.BeanRow;
import com.brsanthu.dataexporter.model.Column;
import com.brsanthu.dataexporter.model.DataExporterCallback;
import com.brsanthu.dataexporter.model.Row;
import com.brsanthu.dataexporter.model.StringColumn;
import com.brsanthu.dataexporter.model.Table;

import static com.brsanthu.dataexporter.util.Util.*;

/**
 * Base class of all exporters. This class holds the instance of {@link Table}, {@link DataWriter}
 * and appropriately calls the DataWriter methods during the exporting.
 * 
 * @author Santhosh Kumar
 */
public abstract class DataExporter {
    
    private Table table = new Table();
    private DataWriter dataWriter = null;
    private boolean startedExporting = false;
    
    protected DataExporter(DataWriter dataWriter) {
        checkForNotNull(dataWriter, "datawriter");
        this.dataWriter = dataWriter;
    }
    
    public DataExporterCallback getCallback() {
        return table.getCallback();
    }



    public void setCallback(DataExporterCallback callback) {
        table.setCallback(callback);
    }

    public void setOutputStream(PrintWriter out) {
    	dataWriter.setOutputStream(out);
    }

    /**
     * Returns the currently assigned {@link DataWriter}
     * 
     * @return the data writer
     */
    public DataWriter getDataWriter() {
        return dataWriter;
    }
    
    /**
     * Returns the current options in the {@link DataWriter}. This is convenience method and is 
     * equivalent to getDataWriter().getOptions()
     * 
     * @return the current data writer options.
     */
    public ExportOptions getOptions() {
        return dataWriter.getOptions();
    }

    /**
     * Adds a set of new {@link StringColumn} using the given strings as column name and title. 
     * Width of the columns would be same as length of names.
     * 

* Note that columns can only be added before any rows. If any of the rows * are already added, this would throw IllegalStateException * * @param columns the list of strings to be added as new {@link StringColumn}s. Cannot be null. * @throws IllegalStateException if rows are already added * @return the current instance of data exporter for method chaining. */ public DataExporter addColumn(String... columns) { checkForNotNull(columns, "columns"); for (String column : columns) { table.addColumn(new StringColumn(column)); } return this; } /** * Adds given list of columns to the table. *

* Note that columns can only be added before any rows. If any of the rows * are already added, this would throw IllegalStateException * * @param columns the list of columns to be added. Cannot be null. * @throws IllegalStateException if rows are already added * @return the current instance of data exporter for method chaining. */ public DataExporter addColumns(Column... columns) { checkForNotNull(columns, "columns"); checkNotExporting(); for (Column column : columns) { table.addColumn(column); } return this; } // /** // * Adds given list of footers to the table. // *

// * Note that footers can be added to the table any time before calling {@link #finishExporting()} // * // * @param footers the list of footers to be added to the table. Cannot be null. // * @return the current instance of data exporter for method chaining. // */ // public DataExporter addFooters(Footer... footers) { // checkForNotNull(footers, "footers"); // // for (Footer footer : footers) { // table.addFooter(footer); // } // // return this; // } /** * Creates a new row with given set of values and adds to the table. If this is the first * row being added, exporting would be started (header and this rows would be exported). *

* If there are less number of values than there are columns, values would be assumed as null. * If there are more values than there are columns, those values would be ignored. * * @param rowValues array of row values to be added as a row. Cannot be null. * @return the current instance of data exporter for method chaining. */ public DataExporter addRow(Object... rowValues) { checkForNotNull(rowValues, "rowValues"); Row row = new Row(); row.add(rowValues); addRows(row); return this; } /** * Adds the given row to the table. If this is the first * row being added, exporting would be started (header and this rows would be exported). *

* If there are less number of values than there are columns, values would be assumed as null. * If there are more values than there are columns, those values would be ignored. * * @param rows array of row values to be added as a row. Cannot be null. * @return the current instance of data exporter for method chaining. */ public DataExporter addRows(Row... rows) { checkForNotNull(rows, "rows"); startExporting(); dataWriter.writeRows(table, Arrays.asList(rows)); return this; } /** * Creates a {@link BeanRow} for each of the given beans and adds to table using {@link #addRows(Row...)} method. * * @param beans array of beans to be added to table as bean rows. Cannot be null. * @return the current instance of data exporter for method chaining. */ public DataExporter addBeanRows(Object... beans) { checkForNotNull(beans, "beans"); for (Object object : beans) { addRows(new BeanRow(object)); } return this; } public DataExporter addBeanRows(List beans) { checkForNotNull(beans, "beans"); for (Object object : beans) { addRows(new BeanRow(object)); } return this; } /** * This would start the data exporting by exporting the table header. After this call, new columns cannot be added. *

* If table is already in exporting mode, this method has no effect. * */ public synchronized void startExporting() { if (startedExporting) { return; } startedExporting = true; dataWriter.beforeTable(table); dataWriter.writeHeader(table); } /** * Finishes the exporting by writing the footers, and end of table. After this call, columns can be readded * to the table. *

* If table was not started to export the data, this method would throw {@link IllegalStateException}. */ public void finishExporting() { if (!startedExporting) { throw new IllegalStateException("Data export has not been started to finish!"); } dataWriter.afterTable(table); dataWriter.flush(); dataWriter.finishExporting(); startedExporting = false; } /** * Checks and throws the exception of data is already started to be exported. */ private void checkNotExporting() { if (startedExporting) { throw new IllegalStateException("DataExporter has already started exporting the data and " + "hence new columns cannot be added."); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy