豁然高

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

POI--各种样式的XSSFCellStyle的生成

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
//背景色、フォント色、枠線より各種XSSFCellStyleの作成して、cellStyleMapに保存する
private HashMap<String, XSSFCellStyle> createXssfCellStyle() {
    HashMap<String, XSSFCellStyle> cellStyleMap = new HashMap<>();
 
    XSSFCellStyle xssfCellStyle;
    String mapKey = "";
    XSSFColor[] xssfColorArr = new XSSFColor[bgColorArr.length];
    XSSFFont[] xssfFontArr = new XSSFFont[fontColorArr.length];
    for(int bgColorIndex=0; bgColorIndex<bgColorArr.length; bgColorIndex++) {
        xssfColorArr[bgColorIndex] = createXssfColor(bgColorArr[bgColorIndex]);
    }
    for(int fontColorIndex=0; fontColorIndex<fontColorArr.length; fontColorIndex++) {
        xssfFontArr[fontColorIndex] = createXssfFont(fontColorArr[fontColorIndex]);
    }
 
    for (int bgColorIndex=0; bgColorIndex<bgColorArr.length; bgColorIndex++) {
        for(int fontColorIndex=0; fontColorIndex<fontColorArr.length; fontColorIndex++) {
            for(int rightBorderNameIndex=0; rightBorderNameIndex<borderNameArr.length; rightBorderNameIndex++ ) {
                for (int bottomBorderNameIndex=0; bottomBorderNameIndex<borderNameArr.length; bottomBorderNameIndex++ ) {
                    for (int dataFormatIndex=0; dataFormatIndex<dataFormatArr.length; dataFormatIndex++) {
                        for (int wrapTextIndex=0; wrapTextIndex < wrapTextArr.length; wrapTextIndex++) {
                            xssfCellStyle = wb.createCellStyle();
                            xssfCellStyle.setFillForegroundColor(xssfColorArr[bgColorIndex]);
                            xssfCellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);
                            xssfCellStyle.setFont(xssfFontArr[fontColorIndex]);
                            xssfCellStyle.setBorderTop(BorderStyle.HAIR);
                            xssfCellStyle.setBorderLeft(BorderStyle.HAIR);
                            xssfCellStyle.setBorderRight(BorderStyle.valueOf(borderNameArr[rightBorderNameIndex]));
                            xssfCellStyle.setBorderBottom(BorderStyle.valueOf(borderNameArr[bottomBorderNameIndex]));
                            xssfCellStyle.setDataFormat(dataFormatArr[dataFormatIndex]);
                            xssfCellStyle.setWrapText(wrapTextArr[wrapTextIndex]);
 
                            //right border name(MEDIUMやHAIR) + bottom border name(MEDIUMやHAIR) + font color(000000など) + background color (ffffffなど)
                            mapKey = borderNameArr[rightBorderNameIndex]
                                    + borderNameArr[bottomBorderNameIndex]
                                    + fontColorArr[fontColorIndex]
                                    + bgColorArr[bgColorIndex]
                                    + dataFormatArr[dataFormatIndex]
                                    + wrapTextKeyArr[wrapTextIndex];
                            cellStyleMap.put(mapKey, xssfCellStyle);
                        }
 
                    }
 
                }
            }
        }
    }
    return cellStyleMap;
}
 
//右枠線のNAME、下枠線のNAME、フォント色、背景色より、合っているXSSFCellStyleを取得
private XSSFCellStyle getXssfCellStyle(String rightBorderName, String bottomBorderName, String fontColor, String bgColor, int dataFormat, boolean isWrapped ) {
    String wrapTextKey = WRAP_TEXT_KEY_FALSE;
    if (isWrapped) {
        wrapTextKey = WRAP_TEXT_KEY_TRUE;
    }
    String mapKey = rightBorderName + bottomBorderName + fontColor + bgColor + dataFormat + wrapTextKey;
    if (!xssfCellStyleMap.containsKey(mapKey)) {
    }
    return xssfCellStyleMap.get(mapKey);
}

  

posted on   豁然高  阅读(3756)  评论(0编辑  收藏  举报

编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示