`

POI操作Excel常用方法总结 .

阅读更多
一、 POI简介
            Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。

二、 HSSF概况
            HSSF 是Horrible SpreadSheet Format的缩写,通过HSSF,你可以用纯Java代码来读取、写入、修改Excel文件。HSSF 为读取操作提供了两类API:usermodel和eventusermodel,即“用户模型”和“事件-用户模型”。

三、 POI EXCEL文档结构类
            HSSFWorkbook excel文档对象

            HSSFSheet excel的sheet HSSFRow excel的行

            HSSFCell excel的单元格 HSSFFont excel字体

            HSSFName 名称 HSSFDataFormat 日期格式

            HSSFHeader sheet头

            HSSFFooter sheet尾

            HSSFCellStyle cell样式

            HSSFDateUtil 日期

            HSSFPrintSetup 打印

            HSSFErrorConstants 错误信息表

四、 EXCEL常用操作方法

1、 得到Excel常用对象           
POIFSFileSystem fs=newPOIFSFileSystem(new FileInputStream("d:/test.xls"));   
//得到Excel工作簿对象    
HSSFWorkbook wb = new HSSFWorkbook(fs);  
//得到Excel工作表对象    
HSSFSheet sheet = wb.getSheetAt(0);   
//得到Excel工作表的行    
HSSFRow row = sheet.getRow(i);  
//得到Excel工作表指定行的单元格    
HSSFCell cell = row.getCell((short) j);  
cellStyle = cell.getCellStyle();//得到单元格样式  
POIFSFileSystem fs=newPOIFSFileSystem(new FileInputStream("d:/test.xls")); 
//得到Excel工作簿对象 
HSSFWorkbook wb = new HSSFWorkbook(fs);
//得到Excel工作表对象 
HSSFSheet sheet = wb.getSheetAt(0); 
//得到Excel工作表的行 
HSSFRow row = sheet.getRow(i);
//得到Excel工作表指定行的单元格 
HSSFCell cell = row.getCell((short) j);
cellStyle = cell.getCellStyle();//得到单元格样式


2、建立Excel常用对象
HSSFWorkbook wb = new HSSFWorkbook();//创建Excel工作簿对象   
HSSFSheet sheet = wb.createSheet("new sheet");//创建Excel工作表对象     
HSSFRow row = sheet.createRow((short)0); //创建Excel工作表的行   
cellStyle = wb.createCellStyle();//创建单元格样式   
row.createCell((short)0).setCellStyle(cellStyle); //创建Excel工作表指定行的单元格   
row.createCell((short)0).setCellValue(1); //设置Excel工作表的值  
HSSFWorkbook wb = new HSSFWorkbook();//创建Excel工作簿对象
HSSFSheet sheet = wb.createSheet("new sheet");//创建Excel工作表对象  
HSSFRow row = sheet.createRow((short)0); //创建Excel工作表的行
cellStyle = wb.createCellStyle();//创建单元格样式
row.createCell((short)0).setCellStyle(cellStyle); //创建Excel工作表指定行的单元格
row.createCell((short)0).setCellValue(1); //设置Excel工作表的值


3、设置sheet名称和单元格内容
wb.setSheetName(1, "第一张工作表",HSSFCell.ENCODING_UTF_16);          
cell.setEncoding((short) 1);      
cell.setCellValue("单元格内容");  
wb.setSheetName(1, "第一张工作表",HSSFCell.ENCODING_UTF_16);        
cell.setEncoding((short) 1);    
cell.setCellValue("单元格内容"); 


4、取得sheet的数目
wb.getNumberOfSheets()   
wb.getNumberOfSheets() 


5、  根据index取得sheet对象
HSSFSheet sheet = wb.getSheetAt(0);  
HSSFSheet sheet = wb.getSheetAt(0);


6、取得有效的行数
int rowcount = sheet.getLastRowNum();  
int rowcount = sheet.getLastRowNum();


7、取得一行的有效单元格个数
row.getLastCellNum();    
row.getLastCellNum(); 
 
8、单元格值类型读写
cell.setCellType(HSSFCell.CELL_TYPE_STRING); //设置单元格为STRING类型   
cell.getNumericCellValue();//读取为数值类型的单元格内容  
cell.setCellType(HSSFCell.CELL_TYPE_STRING); //设置单元格为STRING类型
cell.getNumericCellValue();//读取为数值类型的单元格内容


9、设置列宽、行高
sheet.setColumnWidth((short)column,(short)width);      
row.setHeight((short)height);    
sheet.setColumnWidth((short)column,(short)width);    
row.setHeight((short)height); 


10、添加区域,合并单元格
Region region = new Region((short)rowFrom,(short)columnFrom,(short)rowTo  
,(short)columnTo);//合并从第rowFrom行columnFrom列   
sheet.addMergedRegion(region);// 到rowTo行columnTo的区域      
//得到所有区域       
sheet.getNumMergedRegions()   
Region region = new Region((short)rowFrom,(short)columnFrom,(short)rowTo
,(short)columnTo);//合并从第rowFrom行columnFrom列
sheet.addMergedRegion(region);// 到rowTo行columnTo的区域   
//得到所有区域    
sheet.getNumMergedRegions() 


11、保存Excel文件
FileOutputStream fileOut = new FileOutputStream(path);   
wb.write(fileOut);   
FileOutputStream fileOut = new FileOutputStream(path); 
wb.write(fileOut); 


12、根据单元格不同属性返回字符串数值
public String getCellStringValue(HSSFCell cell) {      
        String cellValue = "";      
        switch (cell.getCellType()) {      
        case HSSFCell.CELL_TYPE_STRING://字符串类型   
           cellValue = cell.getStringCellValue();      
           if(cellValue.trim().equals("")||cellValue.trim().length()<=0)      
                cellValue=" ";      
            break;      
        case HSSFCell.CELL_TYPE_NUMERIC: //数值类型   
            cellValue = String.valueOf(cell.getNumericCellValue());      
            break;      
        case HSSFCell.CELL_TYPE_FORMULA: //公式   
            cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);      
            cellValue = String.valueOf(cell.getNumericCellValue());      
            break;      
        case HSSFCell.CELL_TYPE_BLANK:      
            cellValue=" ";      
            break;      
        case HSSFCell.CELL_TYPE_BOOLEAN:      
           break;      
        case HSSFCell.CELL_TYPE_ERROR:      
            break;      
        default:      
            break;      
        }      
        return cellValue;      
    }     
public String getCellStringValue(HSSFCell cell) {    
        String cellValue = "";    
        switch (cell.getCellType()) {    
        case HSSFCell.CELL_TYPE_STRING://字符串类型
            cellValue = cell.getStringCellValue();    
            if(cellValue.trim().equals("")||cellValue.trim().length()<=0)    
                cellValue=" ";    
            break;    
        case HSSFCell.CELL_TYPE_NUMERIC: //数值类型
            cellValue = String.valueOf(cell.getNumericCellValue());    
            break;    
        case HSSFCell.CELL_TYPE_FORMULA: //公式
            cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);    
            cellValue = String.valueOf(cell.getNumericCellValue());    
            break;    
        case HSSFCell.CELL_TYPE_BLANK:    
            cellValue=" ";    
            break;    
        case HSSFCell.CELL_TYPE_BOOLEAN:    
            break;    
        case HSSFCell.CELL_TYPE_ERROR:    
            break;    
        default:    
            break;    
        }    
        return cellValue;    
    }   



13、常用单元格边框格式
HSSFCellStyle style = wb.createCellStyle();      
style.setBorderBottom(HSSFCellStyle.BORDER_DOTTED);//下边框        
style.setBorderLeft(HSSFCellStyle.BORDER_DOTTED);//左边框        
style.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框        
style.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框    
HSSFCellStyle style = wb.createCellStyle();    
style.setBorderBottom(HSSFCellStyle.BORDER_DOTTED);//下边框     
style.setBorderLeft(HSSFCellStyle.BORDER_DOTTED);//左边框     
style.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框     
style.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框  



14、设置字体和内容位置
HSSFFont f  = wb.createFont();      
f.setFontHeightInPoints((short) 11);//字号       
f.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);//加粗       
style.setFont(f);      
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//左右居中       
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//上下居中       
style.setRotation(short rotation);//单元格内容的旋转的角度       
HSSFDataFormat df = wb.createDataFormat();      
style1.setDataFormat(df.getFormat("0.00%"));//设置单元格数据格式       
cell.setCellFormula(string);//给单元格设公式       
style.setRotation(short rotation);//单元格内容的旋转的角度   
HSSFFont f  = wb.createFont();    
f.setFontHeightInPoints((short) 11);//字号    
f.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);//加粗    
style.setFont(f);    
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//左右居中    
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//上下居中    
style.setRotation(short rotation);//单元格内容的旋转的角度    
HSSFDataFormat df = wb.createDataFormat();    
style1.setDataFormat(df.getFormat("0.00%"));//设置单元格数据格式    
cell.setCellFormula(string);//给单元格设公式    
style.setRotation(short rotation);//单元格内容的旋转的角度 



15、插入图片
//先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray       
      ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();      
      BufferedImage bufferImg = ImageIO.read(new File("ok.jpg"));      
      ImageIO.write(bufferImg,"jpg",byteArrayOut);      
//读进一个excel模版       
FileInputStream fos = new FileInputStream(filePathName+"/stencil.xlt");       
fs = new POIFSFileSystem(fos);      
//创建一个工作薄       
HSSFWorkbook wb = new HSSFWorkbook(fs);      
HSSFSheet sheet = wb.getSheetAt(0);      
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();      
HSSFClientAnchor anchor = new HSSFClientAnchor(0,0,1023,255,(short) 0,0,(short)10,10);           
patriarch.createPicture(anchor , wb.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));    
//先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray    
      ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();    
      BufferedImage bufferImg = ImageIO.read(new File("ok.jpg"));    
      ImageIO.write(bufferImg,"jpg",byteArrayOut);    
//读进一个excel模版    
FileInputStream fos = new FileInputStream(filePathName+"/stencil.xlt");     
fs = new POIFSFileSystem(fos);    
//创建一个工作薄    
HSSFWorkbook wb = new HSSFWorkbook(fs);    
HSSFSheet sheet = wb.getSheetAt(0);    
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();    
HSSFClientAnchor anchor = new HSSFClientAnchor(0,0,1023,255,(short) 0,0,(short)10,10);         
patriarch.createPicture(anchor , wb.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG)); 



16、调整工作表位置
HSSFWorkbook wb = new HSSFWorkbook();     
HSSFSheet sheet = wb.createSheet("format sheet");     
HSSFPrintSetup ps = sheet.getPrintSetup();     
sheet.setAutobreaks(true);     
ps.setFitHeight((short)1);     
ps.setFitWidth((short)1);   
HSSFWorkbook wb = new HSSFWorkbook();   
HSSFSheet sheet = wb.createSheet("format sheet");   
HSSFPrintSetup ps = sheet.getPrintSetup();   
sheet.setAutobreaks(true);   
ps.setFitHeight((short)1);   
ps.setFitWidth((short)1); 

 

17、设置打印区域
HSSFSheet sheet = wb.createSheet("Sheet1");     
wb.setPrintArea(0, "$A$1:$C$2");    
HSSFSheet sheet = wb.createSheet("Sheet1");   
wb.setPrintArea(0, "$A$1:$C$2");  


18、标注脚注
HSSFSheet sheet = wb.createSheet("format sheet");     
HSSFFooter footer = sheet.getFooter()     
footer.setRight( "Page " + HSSFFooter.page() + " of " + HSSFFooter.numPages() );   
HSSFSheet sheet = wb.createSheet("format sheet");   
HSSFFooter footer = sheet.getFooter()   
footer.setRight( "Page " + HSSFFooter.page() + " of " + HSSFFooter.numPages() ); 


19、在工作单中清空行数据,调整行位置
HSSFWorkbook wb = new HSSFWorkbook();     
HSSFSheet sheet = wb.createSheet("row sheet");     
// Create various cells and rows for spreadsheet.      
// Shift rows 6 - 11 on the spreadsheet to the top (rows 0 - 5)      
sheet.shiftRows(5, 10, -5);    
HSSFWorkbook wb = new HSSFWorkbook();   
HSSFSheet sheet = wb.createSheet("row sheet");   
// Create various cells and rows for spreadsheet.   
// Shift rows 6 - 11 on the spreadsheet to the top (rows 0 - 5)   
sheet.shiftRows(5, 10, -5);  


20、选中指定的工作表
HSSFSheet sheet = wb.createSheet("row sheet");     
heet.setSelected(true);     
HSSFSheet sheet = wb.createSheet("row sheet");   
heet.setSelected(true);   



21、工作表的放大缩小
HSSFSheet sheet1 = wb.createSheet("new sheet");     
sheet1.setZoom(1,2);   // 50 percent magnification    
HSSFSheet sheet1 = wb.createSheet("new sheet");   
sheet1.setZoom(1,2);   // 50 percent magnification 



22、头注和脚注
HSSFSheet sheet = wb.createSheet("new sheet");     
HSSFHeader header = sheet.getHeader();     
header.setCenter("Center Header");     
header.setLeft("Left Header");     
header.setRight(HSSFHeader.font("Stencil-Normal", "Italic") +     
HSSFHeader.fontSize((short) 16) + "Right w/ Stencil-Normal Italic font and size 16");  
HSSFSheet sheet = wb.createSheet("new sheet");   
HSSFHeader header = sheet.getHeader();   
header.setCenter("Center Header");   
header.setLeft("Left Header");   
header.setRight(HSSFHeader.font("Stencil-Normal", "Italic") +   
HSSFHeader.fontSize((short) 16) + "Right w/ Stencil-Normal Italic font and size 16");


23、自定义颜色
HSSFCellStyle style = wb.createCellStyle();     
style.setFillForegroundColor(HSSFColor.LIME.index);     
style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);     
HSSFFont font = wb.createFont();     
font.setColor(HSSFColor.RED.index);     
style.setFont(font);     
cell.setCellStyle(style);     
HSSFCellStyle style = wb.createCellStyle();   
style.setFillForegroundColor(HSSFColor.LIME.index);   
style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);   
HSSFFont font = wb.createFont();   
font.setColor(HSSFColor.RED.index);   
style.setFont(font);   
cell.setCellStyle(style);  



24、填充和颜色设置
HSSFCellStyle style = wb.createCellStyle();     
style.setFillBackgroundColor(HSSFColor.AQUA.index);     
style.setFillPattern(HSSFCellStyle.BIG_SPOTS);     
HSSFCell cell = row.createCell((short) 1);     
cell.setCellValue("X");     
style = wb.createCellStyle();     
style.setFillForegroundColor(HSSFColor.ORANGE.index);     
style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);     
cell.setCellStyle(style);   
HSSFCellStyle style = wb.createCellStyle();   
style.setFillBackgroundColor(HSSFColor.AQUA.index);   
style.setFillPattern(HSSFCellStyle.BIG_SPOTS);   
HSSFCell cell = row.createCell((short) 1);   
cell.setCellValue("X");   
style = wb.createCellStyle();   
style.setFillForegroundColor(HSSFColor.ORANGE.index);   
style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);   
cell.setCellStyle(style); 



25、强行刷新单元格公式
HSSFFormulaEvaluator eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);    
private static void updateFormula(Workbook wb,Sheet s,int row){     
        Row r=s.getRow(row);     
        Cell c=null;     
        FormulaEcaluator eval=null;     
        if(wb instanceof HSSFWorkbook)     
            eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);     
        else if(wb instanceof XSSFWorkbook)     
            eval=new XSSFFormulaEvaluator((XSSFWorkbook) wb);     
        for(int i=r.getFirstCellNum();i<r.getLastCellNum();i++){     
            c=r.getCell(i);     
            if(c.getCellType()==Cell.CELL_TYPE_FORMULA)     
                eval.evaluateFormulaCell(c);     
        }     
    }    
HSSFFormulaEvaluator eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);  
private static void updateFormula(Workbook wb,Sheet s,int row){   
        Row r=s.getRow(row);   
        Cell c=null;   
        FormulaEcaluator eval=null;   
        if(wb instanceof HSSFWorkbook)   
            eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);   
        else if(wb instanceof XSSFWorkbook)   
            eval=new XSSFFormulaEvaluator((XSSFWorkbook) wb);   
        for(int i=r.getFirstCellNum();i<r.getLastCellNum();i++){   
            c=r.getCell(i);   
            if(c.getCellType()==Cell.CELL_TYPE_FORMULA)   
                eval.evaluateFormulaCell(c);   
        }   
    }  




说明:FormulaEvaluator提供了evaluateFormulaCell(Cell cell)方法,计算公式保存结果,但不改变公式。而evaluateInCell(Cell cell) 方法是计算公式,并将原公式替换为计算结果,也就是说该单元格的类型不在是Cell.CELL_TYPE_FORMULA而是Cell.CELL_TYPE_NUMBERIC。HSSFFormulaEvaluator提供了静态方法evaluateAllFormu

laCells(HSSFWorkbook wb) ,计算一个Excel文件的所有公式,用起来很方便。

分享到:
评论

相关推荐

    POI操作Excel常用方法总结.docx

    本文主要总结了使用POI操作Excel的一些核心概念和常见方法。 首先,了解POI的基本概念: 1. **POI简介**:Apache POI是一个开源项目,其提供的API使得Java程序能够处理MS Office格式的文档,包括Excel(XLS和XLSX...

    POI操作Excel常用方法总结.pdf

    **Excel常用操作方法**: 1. **获取Excel对象**:首先,通过`POIFSFileSystem`打开文件系统,然后用`HSSFWorkbook`读取Excel工作簿,接着可以获取工作表、行和单元格。例如: ```java POIFSFileSystem fs = new ...

    POI操作Excel常用方法总结

    这篇博客文章“POI操作Excel常用方法总结”可能详细介绍了如何利用Apache POI库在Java环境中读写Excel文件。以下是对该主题的一些关键知识点的详细说明: 1. **Apache POI介绍**: Apache POI是开源项目,提供了...

    POI操作Excel常用方法总结及对excel的读写举例讲述.pdf

    四、EXCEL 常用操作方法 1. 获取 Excel 对象: - 使用 `POIFSFileSystem` 从文件中打开 Excel 文档。 - 通过 `HSSFWorkbook` 的构造函数创建工作簿对象。 - 使用 `getSheetAt(int index)` 获取指定索引的工作表。...

    POI操作Excel常用方法总结及对excel的读写举例讲述.docx

    EXCEL 常用操作方法** - **取得 sheet 的数目**:使用 `HSSFWorkbook` 的 `getNumberOfSheets()` 方法可以获取工作簿中的工作表数量。 - **取得一行的有效单元格个数**:通过调用 `HSSFRow` 的 `getLastCellNum()`...

    PoiExcel_single_save.rar

    总结,"PoiExcel_single_save.rar"项目演示了如何在Java环境中利用Apache POI进行Excel文件的读写操作,并结合ZBar二维码扫描技术实现数据的自动回填。这种组合在数据处理和自动化流程中有着广泛的应用前景,能够...

    java利用poi生成excel报表、处理word文档

    总结,Java POI库为开发者提供了一种高效、灵活的方式来处理Excel报表和Word文档,无论是在生成报表还是数据导入导出、文档格式转换等方面,都是一个不可或缺的工具。通过深入理解和实践,我们可以构建出满足各种...

    POI操作excel2003与2007

    ### POI操作Excel2003与2007 #### 一、POI简介与基础知识 POI是Apache组织下的一个开源项目组件之一,它提供了API来处理Microsoft Office格式的文件,包括Excel、Word、PowerPoint等。本文将重点介绍如何使用POI...

    java_poi操作excel

    **总结**:以上内容详细介绍了如何使用 Apache POI 在 Java 程序中创建和操作 Excel 文件。从创建 Excel 文件到设置单元格的内容,再到添加文档的摘要信息和批注,这些操作都是日常开发中非常实用且常见的功能。掌握...

    poi 解析excel实例

    在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...

    POI实战 .pdf

    4.常用操作 30 4.1注释 30 4.1.1 单表注释 30 4.1.2 多表注释 32 4.1.3 空单元格注释 34 4.2单元格合并与数据读取 34 4.3 窗口冻结 37 4.4 下拉列表 38 5.POI样式 39 5.1 POI样式相关类 39 5.2 单元格边框样式 40 ...

    java_poi导入excel通用工具类V0915

    在Java领域,当你需要读取、写入或修改Excel文件时,POI库是一个非常常用的选择。"java_poi导入excel通用工具类V0915" 提供了一种通用的方式来处理Excel数据的导入工作,它支持多种赋值方式,包括单个对象、列表对象...

    java操作excel的poi手册

    Java操作Excel的POI框架是Java开发者在处理Excel文件时常用的一个库,它允许程序员创建、修改和读取Microsoft Excel文件。本手册将详细介绍如何利用Apache POI进行Java与Excel的交互。 Apache POI是一个开源项目,...

    poi excel 2003 2007

    这两个文件名暗示了可能包含一个Java源代码文件(`ExcelUtil2.java`),该文件可能实现了使用Apache POI操作Excel的具体功能。`q.docx`可能是关于如何使用这些功能的文档或示例说明。为了更好地理解它们的内容,你...

    POI实战-java开发excel详解

    这种映射关系有助于程序员更直观地理解和操作Excel文件。 例如,考虑一个简单的Excel文件,它包含一个名为“Sheet1”的工作表,其中有4行4列的数据。在POI中,可以通过以下方式读取这些数据: - **表关系**:`...

    java开发Excel所需 poi jxl两种jar包

    本文将深入探讨两种常用的Java库:Apache POI和JXL,它们都提供了处理Excel文件的能力。 Apache POI是Apache软件基金会的一个开源项目,它提供了一个强大的API,允许Java开发者读取、写入和修改Microsoft Office...

    java使用poi包和jxl包操作excel的心得

    Java作为一款流行的企业级开发语言,提供了多种工具来操作Excel文件,其中最为常用的当属Apache POI与JXL这两个开源库。 #### 二、Apache POI简介 Apache POI是一个用于读写Microsoft Office格式文件的Java API,...

    POI实战总结

    四、 EXCEL常用操作方法 。 【1、得到Excel常用对象 2、建立Excel常用对象 3、设置sheet名称和单元格内容 4、取得sheet的数目 5、根据index取得sheet对象 6、取得有效的行数 7、取得一行的有效单元格个数 8...

    POI word docx 动态生成.pdf

    同时,POI还支持Apache Commons Lang和Apache Commons IO等常用的Java库,方便处理文本和I/O操作。 总结来说,Apache POI是一个功能强大的Java库,能够方便地在Java程序中创建和修改Word文档(.docx格式)。通过POI...

Global site tag (gtag.js) - Google Analytics