1

Apache POI (3.8 最終リリース) に問題があります。

私の仕事: 基本的な xls/xlsx ドキュメントのデータに従って、いくつかの xls/xlsx ファイルを作成します。

まず、データ (Cell、CellStyle など) をベース ドキュメントから目的のドキュメントにコピーしようとしますCellStyle.cloneFrom。見た目は良いのですが、xlsx ファイル ( xl/styles.xml) を開くと、元のドキュメントとはスタイル (およびフォント) の数が異なることがわかりました。

POI API を使用してソース xls/xlsx ドキュメントの完全なコピーを作成できますか?

ベース ドキュメントのテンプレートを作成し、新しいドキュメントを作成するコード:

public WorkbookTemplate constructTemplate(Workbook wb)
{
    //copy styles from template
    styles = new HashSet<CellStyle>(wb.getNumCellStyles());
    for (short i = 0; i < wb.getNumCellStyles(); i++)
    {
        styles.add(wb.getCellStyleAt(i));
    }
    System.out.println(wb.getNumCellStyles());

    for (int i = 0; i < wb.getNumberOfSheets(); i++)
    {
        Sheet sheet = wb.getSheetAt(i);
        SheetTemplate sheetTemplate = new SheetTemplate(this);
        sheets.add(sheetTemplate.constructTemplate(sheet));
    }

    return this;
}

public Workbook applyTemplate(Workbook wb, JXPathContext context)
{
    preProcessOfWorkBook(wb);
    System.out.println(wb.getNumCellStyles());

    for (SheetTemplate sheetTemplate : sheets)
    {
        Sheet newSheet = wb.createSheet(sheetTemplate.getSheetName());
        sheetTemplate.applyTemplate(newSheet, context);
    }

    return wb;
}

public void preProcessOfWorkBook(Workbook wb)
{
    //Transfer of CellStyles
    styleConvert = new HashMap<CellStyle, CellStyle>(styles.size());
    for (CellStyle style : styles)
    {
        CellStyle bufStyle = wb.createCellStyle();
        bufStyle.cloneStyleFrom(style);
        styleConvert.put(style, bufStyle);
    }
}

WorkbookTemplate クラスの一部であり、constructTemplate - 作成し、applyTemplate - テンプレートから Workbook インスタンスにデータを転送します。

4

0 に答える 0