Apache POI – HSSF, XSSF – 新規ワークブックを作成するには


新しいワークブックを作成するには、HSSFWorkbookクラスを使用します。

package net.tk_factory.example.apache.poi.hssf.workbook;

import java.io.FileOutputStream;
import java.io.IOException;

import net.tk_factory.example.AbstractExample;
import org.apache.log4j.Logger;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

/**
 * Apache POI-HSSFを使用したサンプルプログラムです。<br/>
 * <br/>
 * <b>内容</b>
 * <ol type="1">
 * <li>HSSFWorkbookクラスを使用して、新規ワークブックを作成します。</li>
 * </ol>
 *
 * @author Takafumi Kondo (TK Factory)
 */
public class ExampleCreateWorkbook extends AbstractExample
{
    /** クラス名 */
    private static final String CLASS_NAME =
            ExampleCreateWorkbook.class.getSimpleName();

    /** ロガー */
    private static final Logger LOGGER =
            Logger.getLogger(ExampleCreateWorkbook.class.getName());

    /** 出力ファイル名 */
    private static final String OUT_FILE_NAME =
            EXAMPLE_FILE_DIRECTORY + CLASS_NAME + "Out.xls";

    /**
     * ExampleCreateWorkbookオブジェクトを構築すると、
     * UnsupportedOperationExceptionがスローされます。<br/>
     */
    protected ExampleCreateWorkbook()
    {
        throw new UnsupportedOperationException();
    }

    /**
     * mainメソッドです。<br/>
     *
     * @param args 引数
     */
    public static void main(String[] args)
    {
        LOGGER.info("[START]" + CLASS_NAME);

        FileOutputStream out = null;

        try
        {
            //すでに出力ファイルが存在している場合は削除する
            deleteExistsFile(OUT_FILE_NAME);

            //ワークブックを生成する
            HSSFWorkbook workbook = new HSSFWorkbook();
            LOGGER.debug(workbook.toString());

            //ファイルを保存する
            out = new FileOutputStream(OUT_FILE_NAME);
            workbook.write(out);
        }
        catch (IOException ioex)
        {
            LOGGER.error(getStackTrace(ioex));
        }
        finally
        {
            try
            {
                if (out != null)
                {
                    out.close();
                }
            }
            catch (IOException ioex)
            {
                LOGGER.error(getStackTrace(ioex));
            }

            LOGGER.info("[E N D]" + CLASS_NAME);
        }
    }
}

作成されたファイルを開くと、まだシートを追加していない状態なので、エラーになってしまいます。
ExampleCreateWorkbookOut.xls

また、Microsoft Office 2007で新たに採用された文書フォーマットであるOOXMLにも対応しています。
OOXML形式(.xlsx)でワークブックを作成する場合は、XSSFWorkbookを使用します。

package net.tk_factory.example.apache.poi.xssf.workbook;

import java.io.FileOutputStream;
import java.io.IOException;

import net.tk_factory.example.AbstractExample;
import org.apache.log4j.Logger;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

/**
 * Apache POI-XSSFを使用したサンプルプログラムです。<br/>
 * <br/>
 * <b>内容</b>
 * <ol type="1">
 * <li>XSSFWorkbookクラスを使用して、新規ワークブックを作成します。</li>
 * </ol>
 *
 * @author Takafumi Kondo (TK Factory)
 */
public class ExampleCreateWorkbook4OOXML extends AbstractExample
{
    /** クラス名 */
    private static final String CLASS_NAME =
            ExampleCreateWorkbook4OOXML.class.getSimpleName();

    /** ロガー */
    private static final Logger LOGGER =
            Logger.getLogger(ExampleCreateWorkbook4OOXML.class.getName());

    /** 出力ファイル名 */
    private static final String OUT_FILE_NAME =
            EXAMPLE_FILE_DIRECTORY + CLASS_NAME + "Out.xlsx";

    /**
     * ExampleCreateWorkbook4OOXMLオブジェクトを構築すると、
     * UnsupportedOperationExceptionがスローされます。<br/>
     */
    protected ExampleCreateWorkbook4OOXML()
    {
        throw new UnsupportedOperationException();
    }

    /**
     * mainメソッドです。<br/>
     *
     * @param args 引数
     */
    public static void main(String[] args)
    {
        LOGGER.info("[START]" + CLASS_NAME);

        FileOutputStream out = null;

        try
        {
            //すでに出力ファイルが存在している場合は削除する
            deleteExistsFile(OUT_FILE_NAME);

            //ワークブックを生成する
            XSSFWorkbook workbook = new XSSFWorkbook();
            LOGGER.debug(workbook.toString());

            //ファイルを保存する
            out = new FileOutputStream(OUT_FILE_NAME);
            workbook.write(out);
        }
        catch (IOException ioex)
        {
            LOGGER.error(getStackTrace(ioex));
        }
        finally
        {
            try
            {
                if (out != null)
                {
                    out.close();
                }
            }
            catch (IOException ioex)
            {
                LOGGER.error(getStackTrace(ioex));
            }

            LOGGER.info("[E N D]" + CLASS_NAME);
        }
    }
}

作成されたファイルを開くと、まだシートを追加していない状態なので、エラーになってしまいます。
ExampleCreateWorkbook4OOXMLOut.xlsx

関連記事

  1. サンプルプログラムを実行して作成されたファイルのイメージを追加しました。

  2. ソースを見直し、一部、修正しました。

  1. トラックバック 0

return top