zoukankan      html  css  js  c++  java
  • 生成excel整理(设置边框/字体/颜色/加粗/居中/)

    HSSFWorkbook wb = new HSSFWorkbook();
    HSSFSheet sheet = wb.createSheet();
    HSSFCellStyle setBorder = wb.createCellStyle();
    一、设置背景色:
    setBorder.setFillForegroundColor((short) 13);// 设置背景色
    setBorder.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
    二、设置边框:
    setBorder.setBorderBottom(HSSFCellStyle.BORDER_THIN); //下边框
    setBorder.setBorderLeft(HSSFCellStyle.BORDER_THIN);//左边框
    setBorder.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框
    setBorder.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框
    三、设置居中:
    setBorder.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
    setBorder.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中
    四、设置字体:
    HSSFFont font = wb.createFont();
    font.setFontName("黑体");
    font.setFontHeightInPoints((short) 16);//设置字体大小
    HSSFFont font2 = wb.createFont();
    font2.setFontName("仿宋_GB2312");
    font2.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//粗体显示
    font2.setFontHeightInPoints((short) 12);
    setBorder.setFont(font);//选择需要用到的字体格式
    五、设置列宽:
    sheet.setColumnWidth(0, 3766); //第一个参数代表列id(从0开始),第2个参数代表宽度值
    六、设置自动换行:
    setBorder.setWrapText(true);//设置自动换行
    七、合并单元格:
    Region region1 = new Region(0, (short) 0, 0, (short) 6);
    //参数1:行号 参数2:起始列号 参数3:行号 参数4:终止列号
    sheet.addMergedRegion(region1);
    或者用
    CellRangeAddress region1 = new CellRangeAddress(rowNumber, rowNumber, (short) 0, (short) 11);
    但应注意两个构造方法的参数不是一样的,具体使用哪个取决于POI的不同版本。
    sheet.addMergedRegion(region1);
    目前用过的就这么多,后续有新的会继续添加。
    单独设置合并单元格边框
    RegionUtil.setBorderTop(1, region1, sheet, workbook);
    RegionUtil.setBorderBottom(1, region1, sheet, workbook);
    RegionUtil.setBorderLeft(1, region1, sheet, workbook);
    RegionUtil.setBorderRight(1, region1, sheet, workbook);
     
    八、加边框
      HSSFCellStyle
     cellStyle= wookBook.createCellStyle();
      cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
      cellStyle.setBorderBottom(HSSFCellStyle.BorderBORDER_MEDIUM);
      cellStyle.setBottomBorderColor(HSSFColor.BLACK.index);
      cellStyle.setBorderLeft(HSSFCellStyle.BORDER_MEDIUM);
      cellStyle.setLeftBorderColor(HSSFColor.BLACK.index);
      cellStyle.setBorderRight(HSSFCellStyle.BORDER_MEDIUM);
      cellStyle.setRightBorderColor(HSSFColor.BLACK.index);
      cellStyle.setBorderTop(HSSFCellStyle.BORDER_MEDIUM);
      cellStyle.setTopBorderColor(HSSFColor.BLACK.index);
    九、使用
      获取到某个单元格后在后面set
      row1.createCell(5).setCellStyle(setBorder);
     
    十、宽度自适应

    sheetAt.setColumnWidth(i, res.getBytes().length*2*256);

     
  • 相关阅读:
    后台管理UI的选择
    通过Js对电话和姓名身份证等进行部分隐藏处理
    12个用得着的JQuery代码片段
    Java获取登录用户IP地址
    Android Gson解析json详解
    Android——SD卡工具类——SDCardUtils.java
    【读书笔记】---《失控》
    【读书笔记】.Net并行编程(三)---并行集合
    Wix 安装部署教程(十六) -- 自动生成多语言文件
    【月末轻松篇】--- 那些奇葩的Bugs
  • 原文地址:https://www.cnblogs.com/xueblvip/p/12071245.html
Copyright © 2011-2022 走看看