JAVA POI的使用

本文涉及的产品
可视分析地图(DataV-Atlas),3 个项目,100M 存储空间
数据可视化DataV,5个大屏 1个月
简介: Apache POI是Apache软件基金会的开源项目,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。 .NET的开发人员则可以利用NPOI (POI for .NET) 来存取 Microsoft Office文档的功能。

下载地址

https://archive.apache.org/dist/poi/release/bin/


需要的jar包(我用的是3.10final)


  • Poi-3.10-Final.jar (用于xls)
  • Poi-ooxml-3.10-Final.jar (用于xlsx)
  • Poi-ooxml-schemas-3.10.jar
  • Xmlbeans-2.30.jar
  • dom4j-1.6.1.jar
  • poi-scratchpad-3.10-FINAL-20140208.jar(用于word,ppt)

20180201114234340.png


读doc


publicstaticStringreadWord(Stringname)
    {
FileInputStreamin;
Stringtext=null;
try        {
in=newFileInputStream(name);
WordExtractorextractor=newWordExtractor(in);
text=extractor.getText();
        } 
catch (FileNotFoundExceptione) 
        {
// TODO Auto-generated catch blocke.printStackTrace();
        } catch (Exceptione) {
// TODO Auto-generated catch blocke.printStackTrace();
        }
returntext;
    }


读docx


publicstaticStringreadDocx(Stringpath)
    {
//都是只能用String,不能用Stringbuffer,还不知道原因Stringtext=null; 
try {
InputStreamis=newFileInputStream("doc/aaa.docx");
XWPFDocumentdoc=newXWPFDocument(is);  
XWPFWordExtractorextractor=newXWPFWordExtractor(doc);  
text=extractor.getText(); 
        } catch (IOExceptione) {
// TODO Auto-generated catch blocke.printStackTrace();
        }
returntext;
    }


读xls和xlsx


privatestaticLoggerlog=Logger.getLogger("client"); 
publicstaticStringreadXls(Stringpath)
    {
Stringtext="";  
try         {  
FileInputStreamis=newFileInputStream(path);
HSSFWorkbookexcel=newHSSFWorkbook(is);  
//获取第一个sheet  HSSFSheetsheet0=excel.getSheetAt(0);  
for (IteratorrowIterator=sheet0.iterator();rowIterator.hasNext();) 
             {  
HSSFRowrow=(HSSFRow) rowIterator.next();  
for (Iteratoriterator=row.cellIterator();iterator.hasNext();) 
                 {  
HSSFCellcell=(HSSFCell) iterator.next();  
//根据单元的的类型 读取相应的结果  if(cell.getCellType()==HSSFCell.CELL_TYPE_STRING) text+=cell.getStringCellValue()+"\t";  
elseif(cell.getCellType()==HSSFCell.CELL_TYPE_NUMERIC) text+=cell.getNumericCellValue()+"\t";  
elseif(cell.getCellType()==HSSFCell.CELL_TYPE_FORMULA) text+=cell.getCellFormula()+"\t";  
                 }  
text+="\n";  
             }          
         } 
catch (Exceptione) 
         {  
// TODO Auto-generated catch block  e.printStackTrace();  
log.warn(e);
         }  
returntext; 
    }
publicstaticStringreadXlsx(Stringpath)
    {
Stringtext="";  
try         {  
OPCPackagepkg=OPCPackage.open(path);  
XSSFWorkbookexcel=newXSSFWorkbook(pkg);  
//获取第一个sheet  XSSFSheetsheet0=excel.getSheetAt(0);  
for (IteratorrowIterator=sheet0.iterator();rowIterator.hasNext();) 
              {  
XSSFRowrow=(XSSFRow) rowIterator.next();  
for (Iteratoriterator=row.cellIterator();iterator.hasNext();) 
                  {  
XSSFCellcell=(XSSFCell) iterator.next();  
//根据单元的的类型 读取相应的结果  if(cell.getCellType()==XSSFCell.CELL_TYPE_STRING) text+=cell.getStringCellValue()+"\t";  
elseif(cell.getCellType()==XSSFCell.CELL_TYPE_NUMERIC) text+=cell.getNumericCellValue()+"\t";  
elseif(cell.getCellType()==XSSFCell.CELL_TYPE_FORMULA) text+=cell.getCellFormula()+"\t";  
                  }  
text+="\n";  
              }          
         } 
catch (Exceptione) 
         {  
// TODO Auto-generated catch block  e.printStackTrace();  
log.warn(e);
         }  
returntext;  
    }


1.POI结构与常用类


(1)POI介绍


    Apache POI是Apache软件基金会的开源项目,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。 .NET的开发人员则可以利用NPOI (POI for .NET) 来存取 Microsoft Office文档的功能。


(2)POI结构说明



包名称说明


HSSF提供读写Microsoft Excel XLS格式档案的功能。


XSSF提供读写Microsoft Excel OOXML XLSX格式档案的功能。


HWPF提供读写Microsoft Word DOC格式档案的功能。


HSLF提供读写Microsoft PowerPoint格式档案的功能。


HDGF提供读Microsoft Visio格式档案的功能。


HPBF提供读Microsoft Publisher格式档案的功能。


HSMF提供读Microsoft Outlook格式档案的功能。


(3)POI常用类说明


类名                     说明


HSSFWorkbook           Excel的文档对象


HSSFSheet    


Excel的表单


HSSFRow              


Excel的行


HSSFCell    


Excel的格子单元


HSSFFont                Excel字体



HSSFDataFormat        格子单元的日期格式


HSSFHeader             Excel文档Sheet的页眉


HSSFFooter             Excel文档Sheet的页脚


HSSFCellStyle          格子单元样式


HSSFDateUtil           日期


HSSFPrintSetup        打印



HSSFErrorConstants   错误信息表


2.Excel的基本操作


(1)创建Workbook和Sheet


publicclassTest00{
publicstaticvoidmain(String[] args) throwsIOException {
StringfilePath="d:\\users\\lizw\\桌面\\POI\\sample.xls";//文件路径HSSFWorkbookworkbook=newHSSFWorkbook();//创建Excel文件(Workbook)HSSFSheetsheet=workbook.createSheet();//创建工作表(Sheet)sheet=workbook.createSheet("Test");//创建工作表(Sheet)FileOutputStreamout=newFileOutputStream(filePath);
workbook.write(out);//保存Excel文件out.close();//关闭文件流System.out.println("OK!");
 }
}


(2)创建单元格


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);// 创建行,从0开始HSSFCellcell=row.createCell(0);// 创建行的单元格,也是从0开始cell.setCellValue("李志伟");// 设置单元格内容row.createCell(1).setCellValue(false);// 设置单元格内容,重载row.createCell(2).setCellValue(newDate());// 设置单元格内容,重载row.createCell(3).setCellValue(12.345);// 设置单元格内容,重载


image.png


(3)创建文档摘要信息


workbook.createInformationProperties();//创建文档信息DocumentSummaryInformationdsi=workbook.getDocumentSummaryInformation();//摘要信息dsi.setCategory("类别:Excel文件");//类别dsi.setManager("管理者:李志伟");//管理者dsi.setCompany("公司:--");//公司SummaryInformationsi=workbook.getSummaryInformation();//摘要信息si.setSubject("主题:--");//主题si.setTitle("标题:测试文档");//标题si.setAuthor("作者:李志伟");//作者si.setComments("备注:POI测试文档");//备注


image.png


(4)创建批注


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFPatriarchpatr=sheet.createDrawingPatriarch();
HSSFClientAnchoranchor=patr.createAnchor(0, 0, 0, 0, 5, 1, 8,3);//创建批注位置HSSFCommentcomment=patr.createCellComment(anchor);//创建批注comment.setString(newHSSFRichTextString("这是一个批注段落!"));//设置批注内容comment.setAuthor("李志伟");//设置批注作者comment.setVisible(true);//设置批注默认显示HSSFCellcell=sheet.createRow(2).createCell(1);
cell.setCellValue("测试");
cell.setCellComment(comment);//把批注赋值给单元格


image.png


    创建批注位置HSSFPatriarch.createAnchor(dx1, dy1, dx2, dy2, col1, row1, col2, row2)方法参数说明:


  1. dx1 第1个单元格中x轴的偏移量
  2. dy1 第1个单元格中y轴的偏移量
  3. dx2 第2个单元格中x轴的偏移量
  4. dy2 第2个单元格中y轴的偏移量
  5. col1 第1个单元格的列号
  6. row1 第1个单元格的行号
  7. col2 第2个单元格的列号
  8. row2 第2个单元格的行号


(5)创建页眉和页脚


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFHeaderheader=sheet.getHeader();//得到页眉header.setLeft("页眉左边");
header.setRight("页眉右边");
header.setCenter("页眉中间");
HSSFFooterfooter=sheet.getFooter();//得到页脚footer.setLeft("页脚左边");
footer.setRight("页脚右边");
footer.setCenter("页脚中间");


image.png


    也可以使用Office自带的标签定义,你可以通过HSSFHeader或HSSFFooter访问到它们,都是静态属性,列表如下:


HSSFHeader.tab&A表名HSSFHeader.file&F文件名HSSFHeader.startBold&B粗体开始HSSFHeader.endBold&B粗体结束HSSFHeader.startUnderline&U下划线开始HSSFHeader.endUnderline&U下划线结束HSSFHeader.startDoubleUnderline&E双下划线开始HSSFHeader.endDoubleUnderline&E双下划线结束HSSFHeader.time&T时间HSSFHeader.date&D日期HSSFHeader.numPages&N总页面数HSSFHeader.page&P当前页号


3.Excel的单元格操作


(1)设置格式


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
//设置日期格式--使用Excel内嵌的格式HSSFCellcell=row.createCell(0);
cell.setCellValue(newDate());
HSSFCellStylestyle=workbook.createCellStyle();
style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
cell.setCellStyle(style);
//设置保留2位小数--使用Excel内嵌的格式cell=row.createCell(1);
cell.setCellValue(12.3456789);
style=workbook.createCellStyle();
style.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));
cell.setCellStyle(style);
//设置货币格式--使用自定义的格式cell=row.createCell(2);
cell.setCellValue(12345.6789);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat("¥#,##0"));
cell.setCellStyle(style);
//设置百分比格式--使用自定义的格式cell=row.createCell(3);
cell.setCellValue(0.123456789);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat("0.00%"));
cell.setCellStyle(style);
//设置中文大写格式--使用自定义的格式cell=row.createCell(4);
cell.setCellValue(12345);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat("[DbNum2][$-804]0"));
cell.setCellStyle(style);
//设置科学计数法格式--使用自定义的格式cell=row.createCell(5);
cell.setCellValue(12345);
style=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat("0.00E+00"));
cell.setCellStyle(style);


image.png


   HSSFDataFormat.getFormat和HSSFDataFormat.getBuiltinFormat的区别: 当使用Excel内嵌的(或者说预定义)的格式时,直接用HSSFDataFormat.getBuiltinFormat静态方法即可。当使用自己定义的格式时,必须先调用HSSFWorkbook.createDataFormat(),因为这时在底层会先找有没有匹配的内嵌FormatRecord,如果没有就会新建一个FormatRecord,所以必须先调用这个方法,然后你就可以用获得的HSSFDataFormat实例的getFormat方法了,当然相对而言这种方式比较麻烦,所以内嵌格式还是用HSSFDataFormat.getBuiltinFormat静态方法更加直接一些。


(2)合并单元格


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
//合并列HSSFCellcell=row.createCell(0);
cell.setCellValue("合并列");
CellRangeAddressregion=newCellRangeAddress(0, 0, 0, 5);
sheet.addMergedRegion(region);
//合并行cell=row.createCell(6);
cell.setCellValue("合并行");
region=newCellRangeAddress(0, 5, 6, 6);
sheet.addMergedRegion(region);


image.png


    CellRangeAddress对象其实就是表示一个区域,其构造方法如下:CellRangeAddress(firstRow, lastRow, firstCol, lastCol),参数的说明:


  1. firstRow 区域中第一个单元格的行号
  2. lastRow 区域中最后一个单元格的行号
  3. firstCol 区域中第一个单元格的列号
  4. lastCol 区域中最后一个单元格的列号


   提示: 即使你没有用CreateRow和CreateCell创建过行或单元格,也完全可以直接创建区域然后把这一区域合并,Excel的区域合并信息是单独存储的,和RowRecord、ColumnInfoRecord不存在直接关系。


(3)单元格对齐


HSSFCellcell=row.createCell(0);
cell.setCellValue("单元格对齐");
HSSFCellStylestyle=workbook.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//水平居中style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//垂直居中style.setWrapText(true);//自动换行style.setIndention((short)5);//缩进style.setRotation((short)60);//文本旋转,这里的取值是从-90到90,而不是0-180度。cell.setCellStyle(style);


image.png

 

水平对齐相关参数


  1. 如果是左侧对齐就是 HSSFCellStyle.ALIGN_FILL;
  2. 如果是居中对齐就是 HSSFCellStyle.ALIGN_CENTER;
  3. 如果是右侧对齐就是 HSSFCellStyle.ALIGN_RIGHT;
  4. 如果是跨列举中就是 HSSFCellStyle.ALIGN_CENTER_SELECTION;
  5. 如果是两端对齐就是 HSSFCellStyle.ALIGN_JUSTIFY;
  6. 如果是填充就是 HSSFCellStyle.ALIGN_FILL;


垂直对齐相关参数


  1. 如果是靠上就是 HSSFCellStyle.VERTICAL_TOP;
  2. 如果是居中就是 HSSFCellStyle.VERTICAL_CENTER;
  3. 如果是靠下就是 HSSFCellStyle.VERTICAL_BOTTOM;
  4. 如果是两端对齐就是 HSSFCellStyle.VERTICAL_JUSTIFY;


(4)使用边框


    边框和其他单元格设置一样也是调用CellStyle接口,CellStyle有2种和边框相关的属性,分别是:



边框相关属性

说明

范例

Border+ 方向

边框类型

BorderLeft, BorderRight 等

方向 +BorderColor

边框颜色

TopBorderColor,BottomBorderColor 等


HSSFCellcell=row.createCell(1);
cell.setCellValue("设置边框");
HSSFCellStylestyle=workbook.createCellStyle();
style.setBorderTop(HSSFCellStyle.BORDER_DOTTED);//上边框style.setBorderBottom(HSSFCellStyle.BORDER_THICK);//下边框style.setBorderLeft(HSSFCellStyle.BORDER_DOUBLE);//左边框style.setBorderRight(HSSFCellStyle.BORDER_SLANTED_DASH_DOT);//右边框style.setTopBorderColor(HSSFColor.RED.index);//上边框颜色style.setBottomBorderColor(HSSFColor.BLUE.index);//下边框颜色style.setLeftBorderColor(HSSFColor.GREEN.index);//左边框颜色style.setRightBorderColor(HSSFColor.PINK.index);//右边框颜色cell.setCellStyle(style);


image.png

 

其中边框类型分为以下几种:


边框范例图

对应的静态值

image.png

HSSFCellStyle. BORDER_DOTTED

image.png

HSSFCellStyle. BORDER_HAIR

image.png

HSSFCellStyle. BORDER_DASH_DOT_DOT

image.png

HSSFCellStyle. BORDER_DASH_DOT

image.png

HSSFCellStyle. BORDER_DASHED

image.png

HSSFCellStyle. BORDER_THIN

image.png

HSSFCellStyle. BORDER_MEDIUM_DASH_DOT_DOT

image.png

HSSFCellStyle. BORDER_SLANTED_DASH_DOT

image.png

HSSFCellStyle. BORDER_MEDIUM_DASH_DOT

image.png

HSSFCellStyle. BORDER_MEDIUM_DASHED

image.png

HSSFCellStyle. BORDER_MEDIUM

image.png

HSSFCellStyle. BORDER_THICK

image.png

HSSFCellStyle. BORDER_DOUBLE


(5)设置字体


HSSFCellcell=row.createCell(1);
cell.setCellValue("设置字体");
HSSFCellStylestyle=workbook.createCellStyle();
HSSFFontfont=workbook.createFont();
font.setFontName("华文行楷");//设置字体名称font.setFontHeightInPoints((short)28);//设置字号font.setColor(HSSFColor.RED.index);//设置字体颜色font.setUnderline(FontFormatting.U_SINGLE);//设置下划线font.setTypeOffset(FontFormatting.SS_SUPER);//设置上标下标font.setStrikeout(true);//设置删除线style.setFont(font);
cell.setCellStyle(style);


image.png


下划线选项值:


单下划线 FontFormatting.U_SINGLE


双下划线 FontFormatting.U_DOUBLE


会计用单下划线 FontFormatting.U_SINGLE_ACCOUNTING


会计用双下划线 FontFormatting.U_DOUBLE_ACCOUNTING


无下划线 FontFormatting.U_NONE


    上标下标选项值:


上标 FontFormatting.SS_SUPER


下标 FontFormatting.SS_SUB


普通,默认值 FontFormatting.SS_NONE


(6)背景和纹理


HSSFCellStylestyle=workbook.createCellStyle();
style.setFillForegroundColor(HSSFColor.GREEN.index);//设置图案颜色style.setFillBackgroundColor(HSSFColor.RED.index);//设置图案背景色style.setFillPattern(HSSFCellStyle.SQUARES);//设置图案样式cell.setCellStyle(style);


image.png

 

图案样式及其对应的值:


图案样式 常量

HSSFCellStyle. NO_FILL

HSSFCellStyle. ALT_BARS

HSSFCellStyle. FINE_DOTS
HSSFCellStyle. SPARSE_DOTS
HSSFCellStyle. LESS_DOTS
HSSFCellStyle. LEAST_DOTS

HSSFCellStyle. BRICKS

HSSFCellStyle. BIG_SPOTS
HSSFCellStyle. THICK_FORWARD_DIAG
HSSFCellStyle. THICK_BACKWARD_DIAG
HSSFCellStyle. THICK_VERT_BANDS
HSSFCellStyle. THICK_HORZ_BANDS
HSSFCellStyle. THIN_HORZ_BANDS

HSSFCellStyle. THIN_VERT_BANDS

HSSFCellStyle. THIN_BACKWARD_DIAG

HSSFCellStyle. THIN_FORWARD_DIAG

HSSFCellStyle. SQUARES
HSSFCellStyle. DIAMONDS


(7)设置宽度和高度


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(1);
HSSFCellcell=row.createCell(1);
cell.setCellValue("123456789012345678901234567890");
sheet.setColumnWidth(1, 31*256);//设置第一列的宽度是31个字符宽度row.setHeightInPoints(50);//设置行的高度是50个点



    这里你会发现一个有趣的现象,setColumnWidth的第二个参数要乘以256,这是怎么回事呢?其实,这个参数的单位是1/256个字符宽度,也就是说,这里是把B列的宽度设置为了31个字符。


    设置行高使用HSSFRow对象的setHeight和setHeightInPoints方法,这两个方法的区别在于setHeightInPoints的单位是点,而setHeight的单位是1/20个点,所以setHeight的值永远是setHeightInPoints的20倍。


    你也可以使用HSSFSheet.setDefaultColumnWidth、HSSFSheet.setDefaultRowHeight和HSSFSheet.setDefaultRowHeightInPoints方法设置默认的列宽或行高。


(8)判断单元格是否为日期


  判断单元格是否为日期类型,使用DateUtil.isCellDateFormatted(cell)方法,例如:


HSSFCellcell=row.createCell(1);
cell.setCellValue(newDate());//设置日期数据System.out.println(DateUtil.isCellDateFormatted(cell));//输出:falseHSSFCellStylestyle=workbook.createCellStyle();
style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
cell.setCellStyle(style);//设置日期样式System.out.println(DateUtil.isCellDateFormatted(cell));//输出:true


4.使用Excel公式


(1)基本计算


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
HSSFCellcell=row.createCell(0);
cell.setCellFormula("2+3*4");//设置公式cell=row.createCell(1);
cell.setCellValue(10);
cell=row.createCell(2);
cell.setCellFormula("A1*B1");//设置公式



(2)SUM函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellValue(1);
row.createCell(1).setCellValue(2);
row.createCell(2).setCellValue(3);
row.createCell(3).setCellValue(4);
row.createCell(4).setCellValue(5);
row=sheet.createRow(1);
row.createCell(0).setCellFormula("sum(A1,C1)");//等价于"A1+C1"row.createCell(1).setCellFormula("sum(B1:D1)");//等价于"B1+C1+D1"



(3)日期函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFCellStylestyle=workbook.createCellStyle();
style.setDataFormat(workbook.createDataFormat().getFormat("yyyy-mm-dd"));
HSSFRowrow=sheet.createRow(0);
Calendardate=Calendar.getInstance();//日历对象HSSFCellcell=row.createCell(0);
date.set(2011,2, 7);
cell.setCellValue(date.getTime());
cell.setCellStyle(style);//第一个单元格开始时间设置完成cell=row.createCell(1);
date.set(2014,4, 25);
cell.setCellValue(date.getTime());
cell.setCellStyle(style);//第一个单元格结束时间设置完成cell=row.createCell(3);
cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"y\"),\"年\")");
cell=row.createCell(4);
cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"m\"),\"月\")");
cell=row.createCell(5);
cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"d\"),\"日\")");


 

以上代码中的公式说明:


    DATEDIF(A1,B1,\"y\") :取得 A1 单元格的日期与 B1 单元格的日期的时间间隔。 ( “ y ” : 表示以年为单位 , ” m ”表示以月为单位 ; ” d ”表示以天为单位 ) 。


         CONCATENATE( str1,str2, … ) :连接字符串。


         更多 Excel 的日期函数可参考:http://tonyqus.sinaapp.com/archives/286


(4)字符串相关函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellValue("abcdefg");
row.createCell(1).setCellValue("aa bb cc dd ee fF GG");
row.createCell(3).setCellFormula("UPPER(A1)");
row.createCell(4).setCellFormula("PROPER(B1)");


 

以上代码中的公式说明:


    UPPER( String ) :将文本转换成大写形式。


         PROPER( String ) :将文字串的首字母及任何非字母字符之后的首字母转换成大写。将其余的字母转换成小写。


         更多 Excel 的字符串函数可参考:http://tonyqus.sinaapp.com/archives/289


(5)IF函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellValue(12);
row.createCell(1).setCellValue(23);
row.createCell(3).setCellFormula("IF(A1>B1,\"A1大于B1\",\"A1小于等于B1\")");



    以上代码中的公式说明:


         IF(logical_test,value_if_true,value_if_false)用来用作逻辑判断。其中Logical_test表示计算结果为 TRUE 或 FALSE 的任意值或表达式 ; value_if_true表示当表达式Logical_test的值为TRUE时的返回值;value_if_false表示当表达式Logical_test的值为FALSE时的返回值。


(6)CountIf和SumIf函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellValue(57);
row.createCell(1).setCellValue(89);
row.createCell(2).setCellValue(56);
row.createCell(3).setCellValue(67);
row.createCell(4).setCellValue(60);
row.createCell(5).setCellValue(73);
row.createCell(7).setCellFormula("COUNTIF(A1:F1,\">=60\")");
row.createCell(8).setCellFormula("SUMIF(A1:F1,\">=60\",A1:F1)")



    以上代码中的公式说明:


         COUNTIF(range,criteria):满足某条件的计数的函数。参数range:需要进行读数的计数;参数criteria:条件表达式,只有当满足此条件时才进行计数。


         SumIF(criteria_range, criteria,sum_range):用于统计某区域内满足某条件的值的求和。参数criteria_range:条件测试区域,第二个参数Criteria中的条件将与此区域中的值进行比较;参数criteria:条件测试值,满足条件的对应的sum_range项将进行求和计算;参数sum_range:汇总数据所在区域,求和时会排除掉不满足Criteria条件的对应的项。


(7)Lookup函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellValue(0);
row.createCell(1).setCellValue(59);
row.createCell(2).setCellValue("不及格");
row=sheet.createRow(1);
row.createCell(0).setCellValue(60);
row.createCell(1).setCellValue(69);
row.createCell(2).setCellValue("及格");
row=sheet.createRow(2);
row.createCell(0).setCellValue(70);
row.createCell(1).setCellValue(79);
row.createCell(2).setCellValue("良好");
row=sheet.createRow(3);
row.createCell(0).setCellValue(80);
row.createCell(1).setCellValue(100);
row.createCell(2).setCellValue("优秀");
row=sheet.createRow(4);
row.createCell(0).setCellValue(75);
row.createCell(1).setCellFormula("LOOKUP(A5,$A$1:$A$4,$C$1:$C$4)");
row.createCell(2).setCellFormula("VLOOKUP(A5,$A$1:$C$4,3,true)");


 


以上代码中的公式说明:


    LOOKUP(lookup_value,lookup_vector,result_vector) ,第一个参数:需要查找的内容,本例中指向 A5 单元格,也就是 75 ;第二个参数:比较对象区域,本例中的成绩需要与 $A$1:$A$4 中的各单元格中的值进行比较;第三个参数:查找结果区域,如果匹配到会将此区域中对应的数据返回。如本例中返回$C$1:$C$4 中对应的值。



可能有人会问,字典中没有 75 对应的成绩啊,那么 Excel 中怎么匹配的呢?答案是模糊匹配,并且 LOOKUP 函数只支持模糊匹配。 Excel 会在 $A$1:$A$4 中找小于 75 的最大值,也就是 A3 对应的 70 ,然后将对应的 $C$1:$C$4 区域中的 C3 中的值返回,这就是最终结果“良好”的由来。


    VLOOKUP(lookup_value,lookup_area,result_col,is_fuzzy ) ,第一个参数:需要查找的内容,这里是 A5 单元格;第二个参数:需要比较的表,这里是 $A$1:$C$4 ,注意 VLOOKUP 匹配时只与表中的第一列进行匹配。第三个参数:匹配结果对应的列序号。这里要对应的是成绩列,所以为 3 。第四个参数:指明是否模糊匹配。例子中的 TRUE 表示模糊匹配,与上例中一样。匹配到的是第三行。如果将此参数改为 FALSE ,因为在表中的第 1 列中找不到 75 ,所以会报“#N/A ”的计算错误。


另外,还有与 VLOKUP 类似的 HLOOKUP 。不同的是 VLOOKUP 用于在表格或数值数组的首列查找指定的数值,并由此返回表格或数组当前行中指定列处的数值。而HLOOKUP 用于在表格或数值数组的首行查找指定的数值,并由此返回表格或数组当前列中指定行处的数值。读者可以自已去尝试。


(8)随机数函数


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellFormula("RAND()");//取0-1之间的随机数row.createCell(1).setCellFormula("int(RAND()*100)");//取0-100之间的随机整数row.createCell(2).setCellFormula("rand()*10+10");//取10-20之间的随机实数row.createCell(3).setCellFormula("CHAR(INT(RAND()*26)+97)");//随机小写字母row.createCell(4).setCellFormula("CHAR(INT(RAND()*26)+65)");//随机大写字母//随机大小写字母row.createCell(5).setCellFormula("CHAR(INT(RAND()*26)+if(INT(RAND()*2)=0,97,65))");


    以上代码中的公式说明:


         上面几例中除了用到RAND函数以外,还用到了CHAR函数用来将ASCII码换为字母,INT函数用来取整。值得注意的是INT函数不会四舍五入,无论小数点后是多少都会被舍去。


(9)获得公式的返回值


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
row.createCell(0).setCellValue(7);//A1row.createCell(1).setCellValue(8);//B1HSSFCellcell=row.createCell(2);
cell.setCellFormula("A1*B1+14");
HSSFFormulaEvaluatore=newHSSFFormulaEvaluator(workbook);
cell=e.evaluateInCell(cell);//若Excel文件不是POI创建的,则不必调用此方法System.out.println("公式计算结果:"+cell.getNumericCellValue());


5.使用图形


(1)画线


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFPatriarchpatriarch=sheet.createDrawingPatriarch();
HSSFClientAnchoranchor=newHSSFClientAnchor(0, 0, 0, 0,(short)1, 0,(short)4, 4);
HSSFSimpleShapeline=patriarch.createSimpleShape(anchor);
line.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);//设置图形类型line.setLineStyle(HSSFShape.LINESTYLE_SOLID);//设置图形样式line.setLineWidth(6350);//在POI中线的宽度12700表示1pt,所以这里是0.5pt粗的线条。


    通常,利用POI画图主要有以下几个步骤:


         1. 创建一个Patriarch(注意,一个sheet中通常只创建一个Patriarch对象);


         2. 创建一个Anchor,以确定图形的位置;


         3. 调用Patriarch创建图形;


         4. 设置图形类型(直线,矩形,圆形等)及样式(颜色,粗细等)。


    关于HSSFClientAnchor(dx1,dy1,dx2,dy2,col1,row1,col2,row2)的参数,有必要在这里说明一下:


         dx1:起始单元格的x偏移量,如例子中的0表示直线起始位置距B1单元格左侧的距离;


         dy1:起始单元格的y偏移量,如例子中的0表示直线起始位置距B1单元格上侧的距离;


         dx2:终止单元格的x偏移量,如例子中的0表示直线起始位置距E5单元格左侧的距离;


         dy2:终止单元格的y偏移量,如例子中的0表示直线起始位置距E5单元格上侧的距离;


         col1:起始单元格列序号,从0开始计算;


         row1:起始单元格行序号,从0开始计算,如例子中col1=1,row1=0就表示起始单元格为B1;


         col2:终止单元格列序号,从0开始计算;


         row2:终止单元格行序号,从0开始计算,如例子中col2=4,row2=4就表示起始单元格为E5;


    最后,关于LineStyle属性,有如下一些可选值,对应的效果分别如图所示:



(2)画矩形


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFPatriarchpatriarch=sheet.createDrawingPatriarch();
HSSFClientAnchoranchor=newHSSFClientAnchor(255,122,255, 122, (short)1, 0,(short)4, 3);
HSSFSimpleShaperec=patriarch.createSimpleShape(anchor);
rec.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
rec.setLineStyle(HSSFShape.LINESTYLE_DASHGEL);//设置边框样式rec.setFillColor(255, 0, 0);//设置填充色rec.setLineWidth(25400);//设置边框宽度rec.setLineStyleColor(0, 0, 255);//设置边框颜色


(3)画圆形


    更改上例的代码如下:


rec.setShapeType(HSSFSimpleShape.OBJECT_TYPE_OVAL);//设置图片类型

   




(4)画Grid


    在POI中,本身没有画Grid(网格)的方法。但我们知道Grid其实就是由横线和竖线构成的,所在我们可以通过画线的方式来模拟画Grid。代码如下:


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(2);
row.createCell(1);
row.setHeightInPoints(240);
sheet.setColumnWidth(2, 9000);
intlinesCount=20;
HSSFPatriarchpatriarch=sheet.createDrawingPatriarch();
//因为HSSFClientAnchor中dx只能在0-1023之间,dy只能在0-255之间,这里采用比例的方式doublexRatio=1023.0/ (linesCount*10);
doubleyRatio=255.0/ (linesCount*10);
// 画竖线intx1=0;
inty1=0;
intx2=0;
inty2=200;
for (inti=0; i<linesCount; i++)
{
HSSFClientAnchora2=newHSSFClientAnchor();
a2.setAnchor((short) 2, 2, (int) (x1*xRatio),
 (int) (y1*yRatio), (short) 2, 2, (int) (x2*xRatio),
 (int) (y2*yRatio));
HSSFSimpleShapeshape2=patriarch.createSimpleShape(a2);
shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
x1+=10;
x2+=10;
}
// 画横线x1=0;
y1=0;
x2=200;
y2=0;
for (inti=0; i<linesCount; i++)
{
HSSFClientAnchora2=newHSSFClientAnchor();
a2.setAnchor((short) 2, 2, (int) (x1*xRatio),
 (int) (y1*yRatio), (short) 2, 2, (int) (x2*xRatio),
 (int) (y2*yRatio));
HSSFSimpleShapeshape2=patriarch.createSimpleShape(a2);
shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
y1+=10;
y2+=10;
}


(5)插入图片


HSSFSheetsheet=workbook.createSheet("Test");// 创建工作表(Sheet)FileInputStreamstream=newFileInputStream("d:\\POI\\Apache.gif");
byte[] bytes=newbyte[(int)stream.getChannel().size()];
stream.read(bytes);//读取图片到二进制数组intpictureIdx=workbook.addPicture(bytes,HSSFWorkbook.PICTURE_TYPE_JPEG);
HSSFPatriarchpatriarch=sheet.createDrawingPatriarch();
HSSFClientAnchoranchor=newHSSFClientAnchor(0, 0, 0, 0,(short)0, 0, (short)5, 5);
HSSFPicturepict=patriarch.createPicture(anchor,pictureIdx);
//pict.resize();//自动调节图片大小,图片位置信息可能丢失


(6)从Excel文件提取图片


InputStreaminp=newFileInputStream(filePath);
HSSFWorkbookworkbook=newHSSFWorkbook(inp);//读取现有的Excel文件Listpictures=workbook.getAllPictures();
for(inti=0;i{
HSSFPictureDatapic=pictures.get(i);
Stringext=pic.suggestFileExtension();
if (ext.equals("png"))//判断文件格式 {
FileOutputStreampng=newFileOutputStream("d:\\POI\\Apache.png");
png.write(pic.getData());
png.close();//保存图片 }
}


6.Excel表操作


(1)设置默认工作表


HSSFWorkbookworkbook=newHSSFWorkbook();// 创建Excel文件(Workbook)workbook.createSheet("Test0");// 创建工作表(Sheet)workbook.createSheet("Test1");// 创建工作表(Sheet)workbook.createSheet("Test2");// 创建工作表(Sheet)workbook.createSheet("Test3");// 创建工作表(Sheet)workbook.setActiveSheet(2);//设置默认工作表


(2)重命名工作表


HSSFWorkbookworkbook=newHSSFWorkbook();// 创建Excel文件(Workbook)workbook.createSheet("Test0");// 创建工作表(Sheet)workbook.createSheet("Test1");// 创建工作表(Sheet)workbook.createSheet("Test2");// 创建工作表(Sheet)workbook.createSheet("Test3");// 创建工作表(Sheet)workbook.setSheetName(2, "1234");//重命名工作表


(3)调整表单显示比例


HSSFWorkbookworkbook=newHSSFWorkbook();// 创建Excel文件(Workbook)HSSFSheetsheet1=workbook.createSheet("Test0");// 创建工作表(Sheet)HSSFSheetsheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)HSSFSheetsheet3=workbook.createSheet("Test2");// 创建工作表(Sheet)sheet1.setZoom(1,2);//50%显示比例sheet2.setZoom(2,1);//200%显示比例sheet3.setZoom(1,10);//10%显示比例


(4)显示/隐藏网格线


HSSFWorkbookworkbook=newHSSFWorkbook();// 创建Excel文件(Workbook)HSSFSheetsheet1=workbook.createSheet("Test0");// 创建工作表(Sheet)HSSFSheetsheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)sheet1.setDisplayGridlines(false);//隐藏Excel网格线,默认值为truesheet2.setGridsPrinted(true);//打印时显示网格线,默认值为false


(5)遍历Sheet


StringfilePath="d:\\users\\lizw\\桌面\\POI\\sample.xls";
FileInputStreamstream=newFileInputStream(filePath);
HSSFWorkbookworkbook=newHSSFWorkbook(stream);//读取现有的ExcelHSSFSheetsheet=workbook.getSheet("Test0");//得到指定名称的Sheetfor (Rowrow : sheet)
{
for (Cellcell : row)
 {
System.out.print(cell+"\t");
 }
System.out.println();
}


7.Excel行列操作


(1)组合行、列


HSSFSheetsheet=workbook.createSheet("Test0");// 创建工作表(Sheet)sheet.groupRow(1, 3);//组合行sheet.groupRow(2, 4);//组合行sheet.groupColumn(2, 7);//组合列

    这里简单的介绍一下什么叫做组合:组合分为行组合和列组合,所谓行组合,就是让n行组合成一个集合,能够进行展开和合拢操作。


    使用POI也可以取消组合,例如:sheet.ungroupColumn(1, 3);//取消列组合


(2)锁定列


    在Excel中,有时可能会出现列数太多或是行数太多的情况,这时可以通过锁定列来冻结部分列,不随滚动条滑动,方便查看。


HSSFSheetsheet=workbook.createSheet("Test0");// 创建工作表(Sheet)sheet.createFreezePane(2, 3, 15, 25);//冻结行列


    下面对CreateFreezePane的参数作一下说明:


         第一个参数表示要冻结的列数;


         第二个参数表示要冻结的行数,这里只冻结列所以为0;


         第三个参数表示右边区域可见的首列序号,从1开始计算;


         第四个参数表示下边区域可见的首行序号,也是从1开始计算,这里是冻结列,所以为0;


(3)上下移动行


FileInputStreamstream=newFileInputStream(filePath);
HSSFWorkbookworkbook=newHSSFWorkbook(stream);
HSSFSheetsheet=workbook.getSheet("Test0");
sheet.shiftRows(2, 4, 2);//把第3行到第4行向下移动两行

 

HSSFSheet.shiftRows(startRow, endRow, n)参数说明


         startRow:需要移动的起始行;


         endRow:需要移动的结束行;


         n:移动的位置,正数表示向下移动,负数表示向上移动;



8.Excel的其他功能


(1)设置密码


HSSFSheetsheet=workbook.createSheet("Test0");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(1);
HSSFCellcell=row.createCell(1);
cell.setCellValue("已锁定");
HSSFCellStylelocked=workbook.createCellStyle();
locked.setLocked(true);//设置锁定cell.setCellStyle(locked);
cell=row.createCell(2);
cell.setCellValue("未锁定");
HSSFCellStyleunlocked=workbook.createCellStyle();
unlocked.setLocked(false);//设置不锁定cell.setCellStyle(unlocked);
sheet.protectSheet("password");//设置保护密码


(2)数据有效性


HSSFSheetsheet=workbook.createSheet("Test0");// 创建工作表(Sheet)HSSFRowrow=sheet.createRow(0);
HSSFCellcell=row.createCell(0);
cell.setCellValue("日期列");
CellRangeAddressListregions=newCellRangeAddressList(1, 65535,0, 0);//选定一个区域DVConstraintconstraint=DVConstraint.createDateConstraint(DVConstraint . OperatorType . BETWEEN , "1993-01-01" ,"2014-12-31" , "yyyy-MM-dd" );
HSSFDataValidationdataValidate=newHSSFDataValidation(regions,constraint);
dataValidate.createErrorBox("错误", "你必须输入一个时间!");
sheet.addValidationData(dataValidate);


CellRangeAddressList类表示一个区域,构造函数中的四个参数分别表示起始行序号,终止行序号,起始列序号,终止列序号。65535是一个Sheet的最大行数。另外,CreateDateConstraint的第一个参数除了设置成DVConstraint.OperatorType.BETWEEN外,还可以设置成如下一些值,大家可以自己一个个去试看看效果:



验证的数据类型也有几种选择,如下:



(3)生成下拉式菜单


CellRangeAddressListregions=newCellRangeAddressList(0, 65535,0, 0);
DVConstraintconstraint=DVConstraint.createExplicitListConstraint(newString[] { "C++","Java", "C#" });
HSSFDataValidationdataValidate=newHSSFDataValidation(regions,constraint);
sheet.addValidationData(dataValidate);


(4)打印基本设置


HSSFSheetsheet=workbook.createSheet("Test0");// 创建工作表(Sheet)HSSFPrintSetupprint=sheet.getPrintSetup();//得到打印对象print.setLandscape(false);//true,则表示页面方向为横向;否则为纵向print.setScale((short)80);//缩放比例80%(设置为0-100之间的值)print.setFitWidth((short)2);//设置页宽print.setFitHeight((short)4);//设置页高print.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE);//纸张设置print.setUsePage(true);//设置打印起始页码不使用"自动"print.setPageStart((short)6);//设置打印起始页码sheet.setPrintGridlines(true);//设置打印网格线print.setNoColor(true);//值为true时,表示单色打印print.setDraft(true);//值为true时,表示用草稿品质打印print.setLeftToRight(true);//true表示“先行后列”;false表示“先列后行”print.setNotes(true);//设置打印批注sheet.setAutobreaks(false);//Sheet页自适应页面大小


更详细的打印设置请参考: http://tonyqus.sinaapp.com/archives/271


(5)超链接


HSSFSheetsheet=workbook.createSheet("Test0");
CreationHelpercreateHelper=workbook.getCreationHelper();
// 关联到网站Hyperlinklink=createHelper.createHyperlink(Hyperlink.LINK_URL);
link.setAddress("http://poi.apache.org/");
sheet.createRow(0).createCell(0).setHyperlink(link);
// 关联到当前目录的文件link=createHelper.createHyperlink(Hyperlink.LINK_FILE);
link.setAddress("sample.xls");
sheet.createRow(0).createCell(1).setHyperlink(link);
// e-mail 关联link=createHelper.createHyperlink(Hyperlink.LINK_EMAIL);
link.setAddress("mailto:poi@apache.org?subject=Hyperlinks");
sheet.createRow(0).createCell(2).setHyperlink(link);
//关联到工作簿中的位置link=createHelper.createHyperlink(Hyperlink.LINK_DOCUMENT);
link.setAddress("'Test0'!C3");//Sheet名为Test0的C3位置sheet.createRow(0).createCell(3).setHyperlink(link);


9.POI对Word的基本操作


(1)POI操作Word简介


POI读写Excel功能强大、操作简单。但是POI操作时,一般只用它读取word文档,POI只能能够创建简单的word文档,相对而言POI操作时的功能太少。


(2)POI创建Word文档的简单示例


XWPFDocumentdoc=newXWPFDocument();// 创建Word文件XWPFParagraphp=doc.createParagraph();// 新建一个段落p.setAlignment(ParagraphAlignment.CENTER);// 设置段落的对齐方式p.setBorderBottom(Borders.DOUBLE);//设置下边框p.setBorderTop(Borders.DOUBLE);//设置上边框p.setBorderRight(Borders.DOUBLE);//设置右边框p.setBorderLeft(Borders.DOUBLE);//设置左边框XWPFRunr=p.createRun();//创建段落文本r.setText("POI创建的Word段落文本");
r.setBold(true);//设置为粗体r.setColor("FF0000");//设置颜色p=doc.createParagraph();// 新建一个段落r=p.createRun();
r.setText("POI读写Excel功能强大、操作简单。");
XWPFTabletable=doc.createTable(3, 3);//创建一个表格table.getRow(0).getCell(0).setText("表格1");
table.getRow(1).getCell(1).setText("表格2");
table.getRow(2).getCell(2).setText("表格3");
FileOutputStreamout=newFileOutputStream("d:\\POI\\sample.doc");
doc.write(out);
out.close();


(3)POI读取Word文档里的文字


FileInputStreamstream=newFileInputStream("d:\\POI\\sample.doc");
XWPFDocumentdoc=newXWPFDocument(stream);// 创建Word文件for(XWPFParagraphp : doc.getParagraphs())//遍历段落{
System.out.print(p.getParagraphText());
}
for(XWPFTabletable : doc.getTables())//遍历表格{
for(XWPFTableRowrow : table.getRows())
 {
for(XWPFTableCellcell : row.getTableCells())
 {
System.out.print(cell.getText());
 }
 }
}

相关实践学习
DataV Board用户界面概览
本实验带领用户熟悉DataV Board这款可视化产品的用户界面
阿里云实时数仓实战 - 项目介绍及架构设计
课程简介 1)学习搭建一个数据仓库的过程,理解数据在整个数仓架构的从采集、存储、计算、输出、展示的整个业务流程。 2)整个数仓体系完全搭建在阿里云架构上,理解并学会运用各个服务组件,了解各个组件之间如何配合联动。 3&nbsp;)前置知识要求 &nbsp; 课程大纲 第一章&nbsp;了解数据仓库概念 初步了解数据仓库是干什么的 第二章&nbsp;按照企业开发的标准去搭建一个数据仓库 数据仓库的需求是什么 架构 怎么选型怎么购买服务器 第三章&nbsp;数据生成模块 用户形成数据的一个准备 按照企业的标准,准备了十一张用户行为表 方便使用 第四章&nbsp;采集模块的搭建 购买阿里云服务器 安装 JDK 安装 Flume 第五章&nbsp;用户行为数据仓库 严格按照企业的标准开发 第六章&nbsp;搭建业务数仓理论基础和对表的分类同步 第七章&nbsp;业务数仓的搭建&nbsp; 业务行为数仓效果图&nbsp;&nbsp;
相关文章
|
6月前
|
Java
【java】poi 设置允许西文在单词中间换行
【java】poi 设置允许西文在单词中间换行
|
Java Maven
【Java用法】使用poi写Java代码导出Excel文档的解决方案
【Java用法】使用poi写Java代码导出Excel文档的解决方案
84 0
|
1月前
|
Java Apache
Apache POI java对excel表格进行操作(读、写) 有代码!!!
文章提供了使用Apache POI库在Java中创建和读取Excel文件的详细代码示例,包括写入数据到Excel和从Excel读取数据的方法。
34 0
|
2月前
|
Java Apache Maven
Java中使用poi+poi-tl实现根据模板导出word文档
这个过程不仅简化了文档生成的工作,而且保证了生成文档的一致性与准确性,特别适合于那些需要生成大量文档的自动化场景。通过以上步骤,Java开发人员可以实现高效、可靠的Word文档导出功能。
1192 0
|
4月前
|
easyexcel Java Apache
EasyExcel导入的时候报错Caused by: java.lang.NoClassDefFoundError: org/apache/poi/poifs/filesystem/File
EasyExcel导入的时候报错Caused by: java.lang.NoClassDefFoundError: org/apache/poi/poifs/filesystem/File
325 0
|
6月前
|
Java Apache
Java代码使用POI导出的单元格的字体加粗设置
【5月更文挑战第3天】Java代码使用POI导出的单元格的字体加粗设置
439 1
|
6月前
|
存储 物联网 大数据
Java+BS +saas云HIS系统源码SpringBoot+itext + POI + ureport2数字化医院系统源码
医院云HIS系统是一种运用云计算、大数据、物联网等新兴信息技术的业务和技术平台。它按照现代医疗卫生管理要求,在特定区域内以数字化形式收集、存储、传递和处理医疗卫生行业的数据。通过云HIS系统,可以实现区域内医疗卫生信息资源的集中统管、统一调配、按需服务,为居民、医疗机构、卫生管理机关和其他机构提供云服务。
81 1
|
6月前
|
Java Apache
Java代码使用POI导出的单元格加上边框和背景色
【5月更文挑战第3天】Java代码使用POI导出的单元格加上边框和背景色
615 0
|
6月前
|
Java
POI上传excel的java后台逻辑
POI上传excel的java后台逻辑
|
6月前
|
Java Linux API
下一篇
无影云桌面