poi_point - CSDN
poi 订阅
POI是“Point of Information”的缩写,中文可以翻译为“信息点”。在地理信息系统中,一个POI可以是一栋房子、一个商铺、一个邮筒、一个公交站等。 展开全文
POI是“Point of Information”的缩写,中文可以翻译为“信息点”。在地理信息系统中,一个POI可以是一栋房子、一个商铺、一个邮筒、一个公交站等。
信息
中文翻译
信息点
分    类
有一级类和二级类
中文名
POI信息点
POI全称
Point of Information
POI信息点
传统的地理信息采集方法需要地图测绘人员采用精密的测绘仪器去获取一个信息点的经纬度,然后再标记下来。正因为POI的采集是一个非常费时费事的工作,对一个地理信息系统来说,POI的数量在一定程度代表着整个系统的价值。每个POI包含四方面信息,名称、类别、坐标、分类,全面的POI讯息是丰富导航地图的必备资讯,及时的POI信息点能提醒用户路况的分支及周边建筑的详尽信息,也能方便导航中查到你所需要的各个地方,选择最为便捷和通畅的道路来进行路径规划,因此,导航地图POI多少状况直接影响到导航的好用程度。
收起全文
精华内容
参与话题
  • 基于SSM的POI导入导出Excel实战

    千人学习 2019-04-09 10:12:26
    本课程将给大家分享如何基于SSM实现POI导入导出Excel,并讲解目前企业级JavaWeb应用mvc三层模式的开发流程,可让初学者或者职场萌新掌握如何基于SSM整合第三方框架并采用mvc三层开发模式实现自己的业务模块!
  • Apache POI使用详解

    万次阅读 多人点赞 2019-08-13 11:36:05
    一 :简介开发中经常会设计到excel的处理,如导出Excel,导入Excel到数据库中,操作Excel目前有两个框架,一个是apache 的poi, 另一个是 Java Excel Apache POI 简介是用Java编写的免费开源的跨平台的 Java API,...
    分享一个朋友的人工智能教程(请以“右键”->"在新标签页中打开连接”的方式访问)。比较通俗易懂,风趣幽默,感兴趣的朋友可以去看看。

    一 :简介

    开发中经常会设计到excel的处理,如导出Excel,导入Excel到数据库中,操作Excel目前有两个框架,一个是apache 的poi, 另一个是 Java Excel

    • Apache POI 简介是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office(Excel、WORD、PowerPoint、Visio等)格式档案读和写的功能。POI为“Poor Obfuscation Implementation”的首字母缩写,意为“可怜的模糊实现”。

      官方主页: http://poi.apache.org/index.html
      API文档: http://poi.apache.org/apidocs/index.html

    • Java Excel是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容、创建新的Excel文件、更新已经存在的Excel文件。jxl 由于其小巧 易用的特点, 逐渐已经取代了 POI-excel的地位, 成为了越来越多的java开发人员生成excel文件的首选。

    由于apache poi 在项目中用的比较多,本篇博客只讲解apache poi,不讲jxl


    二:Apache POI常用的类

    • HSSF - 提供读写Microsoft Excel XLS格式档案的功能。
    • XSSF - 提供读写Microsoft Excel OOXML XLSX格式档案的功能。
    • HWPF - 提供读写Microsoft Word DOC97格式档案的功能。
    • XWPF - 提供读写Microsoft Word DOC2003格式档案的功能。
    • HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
    • HDGF - 提供读Microsoft Visio格式档案的功能。
    • HPBF - 提供读Microsoft Publisher格式档案的功能。
    • HSMF - 提供读Microsoft Outlook格式档案的功能。

    在开发中我们经常使用HSSF用来操作Excel处理表格数据,对于其它的不经常使用。

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

    常用的类和方法

    • HSSFWorkbook :工作簿,代表一个excel的整个文档
      • HSSFWorkbook(); // 创建一个新的工作簿
      • HSSFWorkbook(InputStream inputStream); // 创建一个关联输入流的工作簿,可以将一个excel文件封装成工作簿
      • HSSFSheet createSheet(String sheetname); 创建一个新的Sheet
      • HSSFSheet getSheet(String sheetName); 通过名称获取Sheet
      • HSSFSheet getSheetAt(int index); // 通过索引获取Sheet,索引从0开始
      • HSSFCellStyle createCellStyle(); 创建单元格样式
      • int getNumberOfSheets(); 获取sheet的个数
      • setActiveSheet(int index); 设置默认选中的工作表
      • write();
      • write(File newFile);
      • write(OutputStream stream);
    • HSSFSheet:工作表
      • HSSFRow createRow(int rownum); 创建新行,需要指定行号,行号从0开始
      • HSSFRow getRow(int index); 根据索引获取指定的行
      • int addMergedRegion(CellRangeAddress region); 合并单元格
        CellRangeAddress(int firstRow, int lastRow, int firstCol, int lastCol); 单元格范围, 用于合并单元格,需要指定要合并的首行、最后一行、首列、最后一列。
      • autoSizeColumn(int column); 自动调整列的宽度来适应内容
      • getLastRowNum(); 获取最后的行的索引,没有行或者只有一行的时候返回0
      • setColumnWidth(int columnIndex, int width); 设置某一列的宽度,width=字符个数 * 256,例如20个字符的宽度就是20 * 256
    • HSSFRow :行
      • HSSFCell createCell(int column); 创建新的单元格
      • HSSFCell setCell(shot index);
      • HSSFCell getCell(shot index);
      • setRowStyle(HSSFCellStyle style); 设置行样式
      • short getLastCellNum(); 获取最后的单元格号,如果单元格有第一个开始算,lastCellNum就是列的个数
      • setHeightInPoints(float height); 设置行的高度
    • HSSFCell:单元格
      • setCellValue(String value); 设置单元格的值
      • setCellType(); 设置单元格类型,如 字符串、数字、布尔等
      • setCellStyle(); 设置单元格样式
      • String getStringCellValue(); 获取单元格中的字符串值
      • setCellStyle(HSSFCellStyle style); 设置单元格样式,例如字体、加粗、格式化
      • setCellFormula(String formula); 设置计算公式,计算的结果作为单元格的值,也提供了异常常用的函数,如求和"sum(A1,C1)"、日期函数、字符串相关函数、CountIf和SumIf函数、随机数函数等
    • HSSFCellStyle :单元格样式
      • setFont(Font font); 为单元格设置字体样式
      • setAlignment(HorizontalAlignment align); // 设置水平对齐方式
      • setVerticalAlignment(VerticalAlignment align); // 设置垂直对齐方式
      • setFillPattern(FillPatternType fp);
      • setFillForegroundColor(short bg); 设置前景色
      • setFillBackgroundColor(short bg); 设置背景颜色
    • HSSFFont:字体,
      • setColor(short color); // 设置字体颜色
      • setBold(boolean bold); // 设置是否粗体
      • setItalic(boolean italic); 设置倾斜
      • setUnderline(byte underline); 设置下划线
    • HSSFName:名称
    • HSSFDataFormat :日期格式化
    • HSSFHeader : Sheet的头部
    • HSSFFooter :Sheet的尾部
    • HSSFDateUtil :日期工具
    • HSSFPrintSetup :打印设置
    • HSSFErrorConstants:错误信息表

    Excel中的工作簿、工作表、行、单元格中的关系:

    一个Excel文件对应于一个workbook(HSSFWorkbook),
    一个workbook可以有多个sheet(HSSFSheet)组成,
    一个sheet是由多个row(HSSFRow)组成,
    一个row是由多个cell(HSSFCell)组成
    

    三:基础示例

    首先引入apache poi的依赖

    <dependency>  
        <groupId>org.apache.poi</groupId>  
        <artifactId>poi</artifactId>  
        <version>3.8</version>  
    </dependency>
    

    示例一:在桌面上生成一个Excel文件

    public static void createExcel() throws IOException{
    	// 获取桌面路径
    	FileSystemView fsv = FileSystemView.getFileSystemView();
    	String desktop = fsv.getHomeDirectory().getPath();
    	String filePath = desktop + "/template.xls";
    	
    	File file = new File(filePath);
    	OutputStream outputStream = new FileOutputStream(file);
    	HSSFWorkbook workbook = new HSSFWorkbook();
    	HSSFSheet sheet = workbook.createSheet("Sheet1");
    	HSSFRow row = sheet.createRow(0);
    	row.createCell(0).setCellValue("id");
    	row.createCell(1).setCellValue("订单号");
    	row.createCell(2).setCellValue("下单时间");
    	row.createCell(3).setCellValue("个数");
    	row.createCell(4).setCellValue("单价");
    	row.createCell(5).setCellValue("订单金额");
    	row.setHeightInPoints(30); // 设置行的高度
    	
    	HSSFRow row1 = sheet.createRow(1);
    	row1.createCell(0).setCellValue("1");
    	row1.createCell(1).setCellValue("NO00001");
    	
    	// 日期格式化
    	HSSFCellStyle cellStyle2 = workbook.createCellStyle();
    	HSSFCreationHelper creationHelper = workbook.getCreationHelper();
    	cellStyle2.setDataFormat(creationHelper.createDataFormat().getFormat("yyyy-MM-dd HH:mm:ss"));
    	sheet.setColumnWidth(2, 20 * 256); // 设置列的宽度
    	
    	HSSFCell cell2 = row1.createCell(2);
    	cell2.setCellStyle(cellStyle2);
    	cell2.setCellValue(new Date());
    	
    	row1.createCell(3).setCellValue(2);
    	
    	
    	// 保留两位小数
    	HSSFCellStyle cellStyle3 = workbook.createCellStyle();
    	cellStyle3.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));
    	HSSFCell cell4 = row1.createCell(4);
    	cell4.setCellStyle(cellStyle3);
    	cell4.setCellValue(29.5);
    	
    	
    	// 货币格式化
    	HSSFCellStyle cellStyle4 = workbook.createCellStyle();
    	HSSFFont font = workbook.createFont();
    	font.setFontName("华文行楷");
    	font.setFontHeightInPoints((short)15);
    	font.setColor(HSSFColor.RED.index);
    	cellStyle4.setFont(font);
    	
    	HSSFCell cell5 = row1.createCell(5);
    	cell5.setCellFormula("D2*E2");  // 设置计算公式
    	
    	// 获取计算公式的值
    	HSSFFormulaEvaluator e = new HSSFFormulaEvaluator(workbook);
    	cell5 = e.evaluateInCell(cell5);
    	System.out.println(cell5.getNumericCellValue());
    
    	
    	workbook.setActiveSheet(0);
    	workbook.write(outputStream);
    	outputStream.close();
    }
    

    示例2:读取Excel,解析数据

    public static void readExcel() throws IOException{
    	FileSystemView fsv = FileSystemView.getFileSystemView();
    	String desktop = fsv.getHomeDirectory().getPath();
    	String filePath = desktop + "/template.xls";
    	
    	FileInputStream fileInputStream = new FileInputStream(filePath);
    	BufferedInputStream bufferedInputStream = new BufferedInputStream(fileInputStream);
    	POIFSFileSystem fileSystem = new POIFSFileSystem(bufferedInputStream);
    	HSSFWorkbook workbook = new HSSFWorkbook(fileSystem);
    	HSSFSheet sheet = workbook.getSheet("Sheet1");
    	
    	int lastRowIndex = sheet.getLastRowNum();
    	System.out.println(lastRowIndex);
    	for (int i = 0; i <= lastRowIndex; i++) {
    		HSSFRow row = sheet.getRow(i);
    		if (row == null) { break; }
    		
    		short lastCellNum = row.getLastCellNum();
    		for (int j = 0; j < lastCellNum; j++) {
    			String cellValue = row.getCell(j).getStringCellValue();
    			System.out.println(cellValue);
    		}
    	}
    	
    	
    	bufferedInputStream.close();
    }
    

    四:Java Web 中导出和导入Excel

    1、导出示例

    @SuppressWarnings("resource")
    @RequestMapping("/export")    
    public void exportExcel(HttpServletResponse response, HttpSession session, String name) throws Exception {  
    	
    	String[] tableHeaders = {"id", "姓名", "年龄"}; 
    	
    	HSSFWorkbook workbook = new HSSFWorkbook();
    	HSSFSheet sheet = workbook.createSheet("Sheet1");
    	HSSFCellStyle cellStyle = workbook.createCellStyle();    
    	cellStyle.setAlignment(HorizontalAlignment.CENTER);  
    	cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
    	
    	Font font = workbook.createFont();  
    	font.setColor(HSSFColor.RED.index);  
    	font.setBold(true);
    	cellStyle.setFont(font);
    	
    	// 将第一行的三个单元格给合并
    	sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 2));
    	HSSFRow row = sheet.createRow(0);
    	HSSFCell beginCell = row.createCell(0);
    	beginCell.setCellValue("通讯录");	
    	beginCell.setCellStyle(cellStyle);
    	
    	row = sheet.createRow(1);
    	// 创建表头
    	for (int i = 0; i < tableHeaders.length; i++) {
    		HSSFCell cell = row.createCell(i);
    		cell.setCellValue(tableHeaders[i]);
    		cell.setCellStyle(cellStyle);    
    	}
    	
    	List<User> users = new ArrayList<>();
    	users.add(new User(1L, "张三", 20));
    	users.add(new User(2L, "李四", 21));
    	users.add(new User(3L, "王五", 22));
    	
    	for (int i = 0; i < users.size(); i++) {
    		row = sheet.createRow(i + 2);
    		
    		User user = users.get(i);
    		row.createCell(0).setCellValue(user.getId());    
    		row.createCell(1).setCellValue(user.getName());    
    		row.createCell(2).setCellValue(user.getAge());    
    	}
    	
    	OutputStream outputStream = response.getOutputStream(); 
    	response.reset(); 
    	response.setContentType("application/vnd.ms-excel");    
    	response.setHeader("Content-disposition", "attachment;filename=template.xls");      
    
    	workbook.write(outputStream);
    	outputStream.flush();    
    	outputStream.close();
    }
    

    2、导入示例

    1、使用SpringMVC上传文件,需要用到commons-fileupload

    <dependency>
    	<groupId>commons-fileupload</groupId>
    	<artifactId>commons-fileupload</artifactId>
    	<version>1.3</version>
    </dependency>
    

    2、需要在spring的配置文件中配置一下multipartResolver

    <bean name="multipartResolver"  
        	class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  
    	<property name="defaultEncoding" value="UTF-8" />
    </bean>
    

    3、index.jsp

    <a href="/Spring-Mybatis-Druid/user/export">导出</a> <br/>
    
    <form action="/Spring-Mybatis-Druid/user/import" enctype="multipart/form-data" method="post">
    	<input type="file" name="file"/> 
    	<input type="submit" value="导入Excel">
    </form>
    

    4、解析上传的.xls文件

    @SuppressWarnings("resource")
    @RequestMapping("/import")
    public void importExcel(@RequestParam("file") MultipartFile file) throws Exception{
    	InputStream inputStream = file.getInputStream();
    	BufferedInputStream bufferedInputStream = new BufferedInputStream(inputStream);
    	POIFSFileSystem fileSystem = new POIFSFileSystem(bufferedInputStream);
    	HSSFWorkbook workbook = new HSSFWorkbook(fileSystem);
    	//HSSFWorkbook workbook = new HSSFWorkbook(file.getInputStream());
    	HSSFSheet sheet = workbook.getSheetAt(0);
    	
    	int lastRowNum = sheet.getLastRowNum();
    	for (int i = 2; i <= lastRowNum; i++) {
    		HSSFRow row = sheet.getRow(i);
    		int id = (int) row.getCell(0).getNumericCellValue();
    		String name = row.getCell(1).getStringCellValue();
    		int age = (int) row.getCell(2).getNumericCellValue();
    		
    		System.out.println(id + "-" + name + "-" + age);
    	}
    }
    

    导出效果:
    这里写图片描述

    导入效果:
    这里写图片描述

    项目示例代码下载地址:

    http://download.csdn.net/detail/vbirdbest/9861536

    分享一个朋友的人工智能教程(请以“右键”->"在新标签页中打开连接”的方式访问)。比较通俗易懂,风趣幽默,感兴趣的朋友可以去看看。

    五:相关文章:

    http://www.cnblogs.com/Damon-Luo/p/5919656.html

    http://www.cnblogs.com/LiZhiW/p/4313789.html

    展开全文
  • Java导出Excel(Poi详解)

    万次阅读 多人点赞 2019-04-18 09:01:46
    福利: 直接可用的导出,自己根据下边的讲解自行修改,不修改直接用也可以!...Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。 HSSF 是Horrible S...

    福利:

    直接可用的导出,自己根据下边的讲解自行修改,不修改直接用也可以!

    https://blog.csdn.net/w893932747/article/details/89370894

    一、POI简介:

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

    HSSF 是Horrible SpreadSheet Format的缩写,通过HSSF,你可以用纯Java代码来读取、写入、修改Excel文件。

    HSSF 为读取操作提供了两类API:usermodel和eventusermodel,即“用户模型”和“事件-用户模型”。

    二、POI结构说明

    包名称说明

    1. HSSF提供读写Microsoft Excel XLS格式档案的功能。
    2. XSSF提供读写Microsoft Excel OOXML XLSX格式档案的功能。
    3. HWPF提供读写Microsoft Word DOC格式档案的功能。
    4. HSLF提供读写Microsoft PowerPoint格式档案的功能。
    5. HDGF提供读Microsoft Visio格式档案的功能。
    6. HPBF提供读Microsoft Publisher格式档案的功能。
    7. HSMF提供读Microsoft Outlook格式档案的功能。

    三、POI常用类说明

            类名                            说明

    HSSFWorkbook           Excel的文档对象

    HSSFSheet                  Excel的表单

    HSSFRow                    Excel的行

    HSSFCell                     Excel的格子单元

    HSSFFont                    Excel字体

    HSSFDataFormat        格子单元的日期格式

    HSSFHeader               Excel文档Sheet的页眉

    HSSFFooter                Excel文档Sheet的页脚

    HSSFCellStyle            格子单元样式

    HSSFDateUtil             日期

    HSSFPrintSetup         打印

    HSSFErrorConstants   错误信息表

    四、Excel的基本操作

    • 得到Excel常用对象
    //获得Excel对象
        @Test
        public void testExcel1(){
            try {
                //获取系统文档
                POIFSFileSystem fspoi=new POIFSFileSystem(new FileInputStream("/Users/wangjun/temp/demo1.xls"));
                //创建工作薄对象
                HSSFWorkbook workbook=new HSSFWorkbook(fspoi);
                //创建工作表对象
                HSSFSheet sheet=workbook.getSheet("sheet1");
                //得到Excel表格
                HSSFRow row = sheet.getRow(1);
                //得到Excel工作表指定行的单元格
                HSSFCell cell = row.getCell(1);
                System.out.println(cell);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    • 创建Excel文档
        //创建Excel对象
        @Test
        public void testExcel2() throws IOException {
            //创建工作薄对象
            HSSFWorkbook workbook=new HSSFWorkbook();//这里也可以设置sheet的Name
            //创建工作表对象
            HSSFSheet sheet = workbook.createSheet();
            //创建工作表的行
            HSSFRow row = sheet.createRow(0);//设置第一行,从零开始
            row.createCell(2).setCellValue("aaaaaaaaaaaa");//第一行第三列为aaaaaaaaaaaa
            row.createCell(0).setCellValue(new Date());//第一行第一列为日期
            workbook.setSheetName(0,"sheet的Name");//设置sheet的Name
    
            //文档输出
            FileOutputStream out = new FileOutputStream("/Users/wangjun/temp/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()).toString() +".xls");
            workbook.write(out);
            out.close();
        }
    • 创建Excel文档,添加摘要信息

    这个信息添加完是有的,但是在mac下一直找不到怎么查看,有知道的童鞋希望不吝赐教,我是放到Win中查看的。

        //创建文档摘要信息
        @Test
        public void testExcel3() throws IOException {
            //创建HSSFWorkbook工作薄对象
            HSSFWorkbook workbook=new HSSFWorkbook();
            //创建HSSFSheet对象
            HSSFSheet sheet=workbook.createSheet("sheet1");
            //创建行的单元格,从0开始
            HSSFRow row = sheet.createRow(0);
            //创建单元格,从0开始
            HSSFCell cell = row.createCell(0);
            cell.setCellValue("a");
            //一下为简写
            row.createCell(1).setCellValue("aa");
            row.createCell(2).setCellValue("aaa");
            row.createCell(3).setCellValue("aaaa");
    
            //创建文档信息
            workbook.createInformationProperties();
            //获取DocumentSummaryInformation对象
            DocumentSummaryInformation documentSummaryInformation = workbook.getDocumentSummaryInformation();
            documentSummaryInformation.setCategory("类别:Excel文件");//类别
            documentSummaryInformation.setManager("管理者:王军");//管理者
            documentSummaryInformation.setCompany("公司:Action");//公司
    
            //文档输出
            FileOutputStream out = new FileOutputStream("/Users/wangjun/temp/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()).toString() +".xls");
            workbook.write(out);
            out.close();
        }
    • 创建批注
        //创建批注
        @Test
        public void testExcel4() throws IOException {
            //创建Excel工作薄对象
            HSSFWorkbook workbook=new HSSFWorkbook();
            //创建Excel工作表对象
            HSSFSheet sheet = workbook.createSheet("wj");
            HSSFPatriarch patr = sheet.createDrawingPatriarch();
            //创建批注位置(row1-row3:直接理解为高度,col1-col2:直接理解为宽度)
            HSSFClientAnchor anchor = patr.createAnchor(0, 0, 0, 0, 5, 1, 8, 3);
            //创建批注
            HSSFComment comment = patr.createCellComment(anchor);
            //设置批注内容
            comment.setString(new HSSFRichTextString("这是一个批注段落!"));
            //设置批注作者
            comment.setAuthor("wangjun");
            //设置批注默认显示
            comment.setVisible(true);
            HSSFCell cell = sheet.createRow(2).createCell(1);
            cell.setCellValue("测试");
            //把批注赋值给单元格
            cell.setCellComment(comment);
    
            //文档输出
            FileOutputStream out = new FileOutputStream("/Users/wangjun/temp/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()).toString() +".xls");
            workbook.write(out);
            out.close();
        }

    创建批注位置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个单元格的行号
    • 创建页眉和页脚
        //创建页眉页脚
        @Test
        public void testExcel5() throws IOException {
            //创建Excel工作薄对象
            HSSFWorkbook workbook=new HSSFWorkbook();
            HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
            HSSFHeader header =sheet.getHeader();//得到页眉
            header.setLeft("页眉左边");
            header.setRight("页眉右边");
            header.setCenter("页眉中间");
            HSSFFooter footer =sheet.getFooter();//得到页脚
            footer.setLeft("页脚左边");
            footer.setRight("页脚右边");
            footer.setCenter("页脚中间");
    
            //文档输出
            FileOutputStream out = new FileOutputStream("/Users/wangjun/temp/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()).toString() +".xls");
            workbook.write(out);
            out.close();
        }

    五、Excel的单元格操作

        //Excel的单元格操作
        @Test
        public void testExcel6() throws IOException {
            //创建Excel工作薄对象
            HSSFWorkbook workbook=new HSSFWorkbook();
            //创建Excel工作表对象
            HSSFSheet sheet = workbook.createSheet("wj");
            //创建行的单元格,从0开始
            HSSFRow row = sheet.createRow(0);
            //创建单元格
            HSSFCell cell=row.createCell(0);
            //设置值
            cell.setCellValue(new Date());
            //创建单元格样式
            HSSFCellStyle style=workbook.createCellStyle();
            style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
            cell.setCellStyle(style);
            //设置保留2位小数--使用Excel内嵌的格式
            HSSFCell cell1 = row.createCell(1);
            cell1.setCellValue(12.3456789);
            style=workbook.createCellStyle();
            style.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));
            cell1.setCellStyle(style);
            //设置货币格式--使用自定义的格式
            HSSFCell cell2 = row.createCell(2);
            cell2.setCellValue(12345.6789);
            style=workbook.createCellStyle();
            style.setDataFormat(workbook.createDataFormat().getFormat("¥#,##0"));
            cell2.setCellStyle(style);
            //设置百分比格式--使用自定义的格式
            HSSFCell cell3 = row.createCell(3);
            cell3.setCellValue(0.123456789);
            style=workbook.createCellStyle();
            style.setDataFormat(workbook.createDataFormat().getFormat("0.00%"));
            cell3.setCellStyle(style);
            //设置中文大写格式--使用自定义的格式
            HSSFCell cell4 = row.createCell(4);
            cell4.setCellValue(12345);
            style=workbook.createCellStyle();
            style.setDataFormat(workbook.createDataFormat().getFormat("[DbNum2][$-804]0"));
            cell4.setCellStyle(style);
            //设置科学计数法格式--使用自定义的格式
            HSSFCell cell5 = row.createCell(5);
            cell5.setCellValue(12345);
            style=workbook.createCellStyle();
            style.setDataFormat(workbook.createDataFormat().getFormat("0.00E+00"));
            cell5.setCellStyle(style);
    
            //文档输出
            FileOutputStream out = new FileOutputStream("/Users/wangjun/temp/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()).toString() +".xls");
            workbook.write(out);
            out.close();
        }

    HSSFDataFormat.getFormat和HSSFDataFormat.getBuiltinFormat的区别: 

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

    合并单元格

        //合并单元格
        @Test
        public void testExcel7() throws IOException {
            //创建Excel工作薄对象
            HSSFWorkbook workbook=new HSSFWorkbook();
            //创建Excel工作表对象
            HSSFSheet sheet = workbook.createSheet("wj");
            //创建行的单元格,从0开始
            HSSFRow row = sheet.createRow(0);
            //创建单元格
            HSSFCell cell=row.createCell(0);
            //设置值
            cell.setCellValue(new Date());
            //合并列
            cell.setCellValue("合并列");
            CellRangeAddress region=new CellRangeAddress(0, 0, 0, 5);
            sheet.addMergedRegion(region);
            //合并行
            HSSFCell cell1 = row.createCell(6);
            cell1.setCellValue("合并行");
            region=new CellRangeAddress(0, 5, 6, 6);
            sheet.addMergedRegion(region);
    
            //文档输出
            FileOutputStream out = new FileOutputStream("/Users/wangjun/temp/" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date()).toString() +".xls");
            workbook.write(out);
            out.close();
        }

    CellRangeAddress对象其实就是表示一个区域,其构造方法如下:

    CellRangeAddress(firstRow, lastRow, firstCol, lastCol),参数的说明:

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

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

    (3)单元格对齐

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

         水平对齐相关参数

    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 等

    1. HSSFCell cell=row.createCell(1);
    2. cell.setCellValue("设置边框");
    3. HSSFCellStyle style=workbook.createCellStyle();
    4. style.setBorderTop(HSSFCellStyle.BORDER_DOTTED);//上边框
    5. style.setBorderBottom(HSSFCellStyle.BORDER_THICK);//下边框
    6. style.setBorderLeft(HSSFCellStyle.BORDER_DOUBLE);//左边框
    7. style.setBorderRight(HSSFCellStyle.BORDER_SLANTED_DASH_DOT);//右边框
    8. style.setTopBorderColor(HSSFColor.RED.index);//上边框颜色
    9. style.setBottomBorderColor(HSSFColor.BLUE.index);//下边框颜色
    10. style.setLeftBorderColor(HSSFColor.GREEN.index);//左边框颜色
    11. style.setRightBorderColor(HSSFColor.PINK.index);//右边框颜色
    12. cell.setCellStyle(style);

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

    边框范例图

    对应的静态值

    HSSFCellStyle. BORDER_DOTTED

    HSSFCellStyle. BORDER_HAIR

    HSSFCellStyle. BORDER_DASH_DOT_DOT

    HSSFCellStyle. BORDER_DASH_DOT

    HSSFCellStyle. BORDER_DASHED

    HSSFCellStyle. BORDER_THIN

    HSSFCellStyle. BORDER_MEDIUM_DASH_DOT_DOT

    HSSFCellStyle. BORDER_SLANTED_DASH_DOT

    HSSFCellStyle. BORDER_MEDIUM_DASH_DOT

    HSSFCellStyle. BORDER_MEDIUM_DASHED

    HSSFCellStyle. BORDER_MEDIUM

    HSSFCellStyle. BORDER_THICK

    HSSFCellStyle. BORDER_DOUBLE

    (5)设置字体

    1. HSSFCell cell = row.createCell(1);
    2. cell.setCellValue("设置字体");
    3. HSSFCellStyle style = workbook.createCellStyle();
    4. HSSFFont font = workbook.createFont();
    5. font.setFontName("华文行楷");//设置字体名称
    6. font.setFontHeightInPoints((short)28);//设置字号
    7. font.setColor(HSSFColor.RED.index);//设置字体颜色
    8. font.setUnderline(FontFormatting.U_SINGLE);//设置下划线
    9. font.setTypeOffset(FontFormatting.SS_SUPER);//设置上标下标
    10. font.setStrikeout(true);//设置删除线
    11. style.setFont(font);
    12. cell.setCellStyle(style);

    下划线选项值:

    单下划线 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)背景和纹理

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

         图案样式及其对应的值:

    图案样式

    常量

    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)设置宽度和高度

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(1);
    3. HSSFCell cell = row.createCell(1);
    4. cell.setCellValue("123456789012345678901234567890");
    5. sheet.setColumnWidth(1, 31 * 256);//设置第一列的宽度是31个字符宽度
    6. 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)方法,例如:

    1. HSSFCell cell = row.createCell(1);
    2. cell.setCellValue(new Date());//设置日期数据
    3. System.out.println(DateUtil.isCellDateFormatted(cell));//输出:false
    4. HSSFCellStyle style =workbook.createCellStyle();
    5. style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
    6. cell.setCellStyle(style);//设置日期样式
    7. System.out.println(DateUtil.isCellDateFormatted(cell));//输出:true

    4.使用Excel公式

    (1)基本计算

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. HSSFCell cell = row.createCell(0);
    4. cell.setCellFormula("2+3*4");//设置公式
    5. cell = row.createCell(1);
    6. cell.setCellValue(10);
    7. cell = row.createCell(2);
    8. cell.setCellFormula("A1*B1");//设置公式

    (2)SUM函数

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

    (3)日期函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFCellStyle style=workbook.createCellStyle();
    3. style.setDataFormat(workbook.createDataFormat().getFormat("yyyy-mm-dd"));
    4. HSSFRow row = sheet.createRow(0);
    5. Calendar date=Calendar.getInstance();//日历对象
    6. HSSFCell cell=row.createCell(0);
    7. date.set(2011,2, 7);
    8. cell.setCellValue(date.getTime());
    9. cell.setCellStyle(style);//第一个单元格开始时间设置完成
    10. cell=row.createCell(1);
    11. date.set(2014,4, 25);
    12. cell.setCellValue(date.getTime());
    13. cell.setCellStyle(style);//第一个单元格结束时间设置完成
    14. cell=row.createCell(3);
    15. cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"y\"),\"年\")");
    16. cell=row.createCell(4);
    17. cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"m\"),\"月\")");
    18. cell=row.createCell(5);
    19. 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)字符串相关函数

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

        

    以上代码中的公式说明:

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

     

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

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

    (5)IF函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. row.createCell(0).setCellValue(12);
    4. row.createCell(1).setCellValue(23);
    5. 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函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. row.createCell(0).setCellValue(57);
    4. row.createCell(1).setCellValue(89);
    5. row.createCell(2).setCellValue(56);
    6. row.createCell(3).setCellValue(67);
    7. row.createCell(4).setCellValue(60);
    8. row.createCell(5).setCellValue(73);
    9. row.createCell(7).setCellFormula("COUNTIF(A1:F1,\">=60\")");
    10. 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函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. row.createCell(0).setCellValue(0);
    4. row.createCell(1).setCellValue(59);
    5. row.createCell(2).setCellValue("不及格");
    6. row = sheet.createRow(1);
    7. row.createCell(0).setCellValue(60);
    8. row.createCell(1).setCellValue(69);
    9. row.createCell(2).setCellValue("及格");
    10. row = sheet.createRow(2);
    11. row.createCell(0).setCellValue(70);
    12. row.createCell(1).setCellValue(79);
    13. row.createCell(2).setCellValue("良好");
    14. row = sheet.createRow(3);
    15. row.createCell(0).setCellValue(80);
    16. row.createCell(1).setCellValue(100);
    17. row.createCell(2).setCellValue("优秀");
    18. row = sheet.createRow(4);
    19. row.createCell(0).setCellValue(75);
    20. row.createCell(1).setCellFormula("LOOKUP(A5,$A$1:$A$4,$C$1:$C$4)");
    21. 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)随机数函数

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

         以上代码中的公式说明:

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

    (9)获得公式的返回值

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

    5.使用图形

    (1)画线

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFPatriarch patriarch=sheet.createDrawingPatriarch();
    3. HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short)1, 0,(short)4, 4);
    4. HSSFSimpleShape line = patriarch.createSimpleShape(anchor);
    5. line.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);//设置图形类型
    6. line.setLineStyle(HSSFShape.LINESTYLE_SOLID);//设置图形样式
    7. 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)画矩形

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFPatriarch patriarch=sheet.createDrawingPatriarch();
    3. HSSFClientAnchor anchor = new HSSFClientAnchor(255,122,255, 122, (short)1, 0,(short)4, 3);
    4. HSSFSimpleShape rec = patriarch.createSimpleShape(anchor);
    5. rec.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
    6. rec.setLineStyle(HSSFShape.LINESTYLE_DASHGEL);//设置边框样式
    7. rec.setFillColor(255, 0, 0);//设置填充色
    8. rec.setLineWidth(25400);//设置边框宽度
    9. rec.setLineStyleColor(0, 0, 255);//设置边框颜色

    (3)画圆形

         更改上例的代码如下:

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

    (4)画Grid

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

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(2);
    3. row.createCell(1);
    4. row.setHeightInPoints(240);
    5. sheet.setColumnWidth(2, 9000);
    6. int linesCount = 20;
    7. HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
    8. //因为HSSFClientAnchor中dx只能在0-1023之间,dy只能在0-255之间,这里采用比例的方式
    9. double xRatio = 1023.0 / (linesCount * 10);
    10. double yRatio = 255.0 / (linesCount * 10);
    11. // 画竖线
    12. int x1 = 0;
    13. int y1 = 0;
    14. int x2 = 0;
    15. int y2 = 200;
    16. for (int i = 0; i < linesCount; i++)
    17. {
    18.  HSSFClientAnchor a2 = new HSSFClientAnchor();
    19. a2.setAnchor((short) 2, 2, (int) (x1 * xRatio),
    20.  (int) (y1 * yRatio), (short) 2, 2, (int) (x2 * xRatio),
    21.  (int) (y2 * yRatio));
    22.  HSSFSimpleShape shape2 = patriarch.createSimpleShape(a2);
    23. shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
    24. x1 += 10;
    25. x2 += 10;
    26. }
    27. // 画横线
    28. x1 = 0;
    29. y1 = 0;
    30. x2 = 200;
    31. y2 = 0;
    32. for (int i = 0; i < linesCount; i++)
    33. {
    34.  HSSFClientAnchor a2 = new HSSFClientAnchor();
    35. a2.setAnchor((short) 2, 2, (int) (x1 * xRatio),
    36.  (int) (y1 * yRatio), (short) 2, 2, (int) (x2 * xRatio),
    37.  (int) (y2 * yRatio));
    38.  HSSFSimpleShape shape2 = patriarch.createSimpleShape(a2);
    39. shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
    40. y1 += 10;
    41. y2 += 10;
    42. }

    (5)插入图片

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. FileInputStream stream=newFileInputStream("d:\\POI\\Apache.gif");
    3. byte[] bytes=new byte[(int)stream.getChannel().size()];
    4. stream.read(bytes);//读取图片到二进制数组
    5. int pictureIdx = workbook.addPicture(bytes,HSSFWorkbook.PICTURE_TYPE_JPEG);
    6. HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
    7. HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short)0, 0, (short)5, 5);
    8. HSSFPicture pict = patriarch.createPicture(anchor,pictureIdx);
    9. //pict.resize();//自动调节图片大小,图片位置信息可能丢失

    (6)从Excel文件提取图片

    1. InputStream inp = new FileInputStream(filePath);
    2. HSSFWorkbook workbook = new HSSFWorkbook(inp);//读取现有的Excel文件
    3. List<HSSFPictureData> pictures = workbook.getAllPictures();
    4. for(int i=0;i<pictures.size();i++)
    5. {
    6.  HSSFPictureData pic=pictures.get(i);
    7.  String ext = pic.suggestFileExtension();
    8.  if (ext.equals("png"))//判断文件格式
    9.  {
    10.  FileOutputStream png=newFileOutputStream("d:\\POI\\Apache.png");
    11. png.write(pic.getData());
    12. png.close();//保存图片
    13.  }
    14. }

    6.Excel表操作

    (1)设置默认工作表

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. workbook.createSheet("Test2");// 创建工作表(Sheet)
    5. workbook.createSheet("Test3");// 创建工作表(Sheet)
    6. workbook.setActiveSheet(2);//设置默认工作表

    (2)重命名工作表

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. workbook.createSheet("Test2");// 创建工作表(Sheet)
    5. workbook.createSheet("Test3");// 创建工作表(Sheet)
    6. workbook.setSheetName(2, "1234");//重命名工作表

    (3)调整表单显示比例

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. HSSFSheet sheet1= workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. HSSFSheet sheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. HSSFSheet sheet3=workbook.createSheet("Test2");// 创建工作表(Sheet)
    5. sheet1.setZoom(1,2);//50%显示比例
    6. sheet2.setZoom(2,1);//200%显示比例
    7. sheet3.setZoom(1,10);//10%显示比例

    (4)显示/隐藏网格线

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. HSSFSheet sheet1= workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. HSSFSheet sheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. sheet1.setDisplayGridlines(false);//隐藏Excel网格线,默认值为true
    5. sheet2.setGridsPrinted(true);//打印时显示网格线,默认值为false

    (5)遍历Sheet

    1. String filePath = "d:\\users\\lizw\\桌面\\POI\\sample.xls";
    2. FileInputStream stream = new FileInputStream(filePath);
    3. HSSFWorkbook workbook = new HSSFWorkbook(stream);//读取现有的Excel
    4. HSSFSheet sheet= workbook.getSheet("Test0");//得到指定名称的Sheet
    5. for (Row row : sheet)
    6. {
    7.  for (Cell cell : row)
    8.  {
    9.  System.out.print(cell + "\t");
    10.  }
    11.  System.out.println();
    12. }

    7.Excel行列操作

    (1)组合行、列

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

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

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

    (2)锁定列

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

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

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

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

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

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

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

    (3)上下移动行

    1. FileInputStream stream = new FileInputStream(filePath);
    2. HSSFWorkbook workbook = new HSSFWorkbook(stream);
    3. HSSFSheet sheet = workbook.getSheet("Test0");
    4. sheet.shiftRows(2, 4, 2);//把第3行到第4行向下移动两行

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

              startRow:需要移动的起始行;

              endRow:需要移动的结束行;

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

     

    8.Excel的其他功能

    (1)设置密码

    1. HSSFSheet sheet= workbook.createSheet("Test0");// 创建工作表(Sheet)
    2. HSSFRow row=sheet.createRow(1);
    3. HSSFCell cell=row.createCell(1);
    4. cell.setCellValue("已锁定");
    5. HSSFCellStyle locked = workbook.createCellStyle();
    6. locked.setLocked(true);//设置锁定
    7. cell.setCellStyle(locked);
    8. cell=row.createCell(2);
    9. cell.setCellValue("未锁定");
    10. HSSFCellStyle unlocked = workbook.createCellStyle();
    11. unlocked.setLocked(false);//设置不锁定
    12. cell.setCellStyle(unlocked);
    13. sheet.protectSheet("password");//设置保护密码

    (2)数据有效性

    1. HSSFSheet sheet= workbook.createSheet("Test0");// 创建工作表(Sheet)
    2. HSSFRow row=sheet.createRow(0);
    3. HSSFCell cell=row.createCell(0);
    4. cell.setCellValue("日期列");
    5. CellRangeAddressList regions = new CellRangeAddressList(1, 65535,0, 0);//选定一个区域
    6. DVConstraint constraint = DVConstraint.createDateConstraint(DVConstraint . OperatorType . BETWEEN , "1993-01-01" ,"2014-12-31" , "yyyy-MM-dd" );
    7. HSSFDataValidation dataValidate = new HSSFDataValidation(regions,constraint);
    8. dataValidate.createErrorBox("错误", "你必须输入一个时间!");
    9. sheet.addValidationData(dataValidate);

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

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

    (3)生成下拉式菜单

    1. CellRangeAddressList regions = new CellRangeAddressList(0, 65535,0, 0);
    2. DVConstraint constraint =DVConstraint.createExplicitListConstraint(new String[] { "C++","Java", "C#" });
    3. HSSFDataValidation dataValidate = new HSSFDataValidation(regions,constraint);
    4. sheet.addValidationData(dataValidate);

    (4)打印基本设置

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

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

    (5)超链接

    1. HSSFSheet sheet = workbook.createSheet("Test0");
    2. CreationHelper createHelper = workbook.getCreationHelper();
    3. // 关联到网站
    4. Hyperlink link =createHelper.createHyperlink(Hyperlink.LINK_URL);
    5. link.setAddress("http://poi.apache.org/");
    6. sheet.createRow(0).createCell(0).setHyperlink(link);
    7. // 关联到当前目录的文件
    8. link = createHelper.createHyperlink(Hyperlink.LINK_FILE);
    9. link.setAddress("sample.xls");
    10. sheet.createRow(0).createCell(1).setHyperlink(link);
    11. // e-mail 关联
    12. link = createHelper.createHyperlink(Hyperlink.LINK_EMAIL);
    13. link.setAddress("mailto:poi@apache.org?subject=Hyperlinks");
    14. sheet.createRow(0).createCell(2).setHyperlink(link);
    15. //关联到工作簿中的位置
    16. link = createHelper.createHyperlink(Hyperlink.LINK_DOCUMENT);
    17. link.setAddress("'Test0'!C3");//Sheet名为Test0的C3位置
    18. sheet.createRow(0).createCell(3).setHyperlink(link);

    9.POI对Word的基本操作

    (1)POI操作Word简介

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

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

    1. XWPFDocument doc = new XWPFDocument();// 创建Word文件
    2. XWPFParagraph p = doc.createParagraph();// 新建一个段落
    3. p.setAlignment(ParagraphAlignment.CENTER);// 设置段落的对齐方式
    4. p.setBorderBottom(Borders.DOUBLE);//设置下边框
    5. p.setBorderTop(Borders.DOUBLE);//设置上边框
    6. p.setBorderRight(Borders.DOUBLE);//设置右边框
    7. p.setBorderLeft(Borders.DOUBLE);//设置左边框
    8. XWPFRun r = p.createRun();//创建段落文本
    9. r.setText("POI创建的Word段落文本");
    10. r.setBold(true);//设置为粗体
    11. r.setColor("FF0000");//设置颜色
    12. p = doc.createParagraph();// 新建一个段落
    13. r = p.createRun();
    14. r.setText("POI读写Excel功能强大、操作简单。");
    15. XWPFTable table= doc.createTable(3, 3);//创建一个表格
    16. table.getRow(0).getCell(0).setText("表格1");
    17. table.getRow(1).getCell(1).setText("表格2");
    18. table.getRow(2).getCell(2).setText("表格3");
    19. FileOutputStream out = newFileOutputStream("d:\\POI\\sample.doc");
    20. doc.write(out);
    21. out.close();

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

    1. FileInputStream stream = newFileInputStream("d:\\POI\\sample.doc");
    2. XWPFDocument doc = new XWPFDocument(stream);// 创建Word文件
    3. for(XWPFParagraph p : doc.getParagraphs())//遍历段落
    4. {
    5.  System.out.print(p.getParagraphText());
    6. }
    7. for(XWPFTable table : doc.getTables())//遍历表格
    8. {
    9.  for(XWPFTableRow row : table.getRows())
    10.  {
    11.  for(XWPFTableCell cell : row.getTableCells())
    12.  {
    13.  System.out.print(cell.getText());
    14.  }
    15.  }
    16. }

     

    展开全文
  • poi简介与简单使用

    万次阅读 多人点赞 2020-06-22 11:31:06
    POI是Apache软件基金会用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程序对Microsoft Office格式档案读和写的功能。POI为“Poor Obfuscation Implementation”的首字母缩写,意为“简洁版的...

    简介:

    POI是Apache软件基金会用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程序对Microsoft Office格式档案读和写的功能。POI为“Poor Obfuscation Implementation”的首字母缩写,意为“简洁版的模糊实现”。
    所以POI的主要功能是可以用Java操作Microsoft Office的相关文件,但是一般我们都是用来操作Excel相关文件。

    使用前提 :

    所需jar包,在pom中添加如下坐标即可

    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi</artifactId>
        <version>3.17</version>
    </dependency>
    <dependency>
        <groupId>org.apache.poi</groupId>
        <artifactId>poi-ooxml</artifactId>
        <version>3.17</version>
    </dependency>
    

    注意:

    操作Excel文件区分版本:
    2003版本(包含2003)以前的扩展名为.xls需要用HSSFWorkbook类操作
    2007版本(包含2007)以后的扩展名为.xlsx需要用XSSFWorkbook类操作

    导出

    2007版本(包含2007)以后的扩展名为.xlsx需要用XSSFWorkbook类操作

    import org.apache.poi.xssf.usermodel.XSSFCell;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    import java.io.File;
    import java.io.FileOutputStream;
    import java.io.IOException;
    
    /**
     * Created by Administrator on 2019\3\9 0009.
     */
    public class PoiTest {
    
        public static void main(String[] args) throws IOException {
    
    
            //创建工作簿 类似于创建Excel文件
            XSSFWorkbook workbook=new XSSFWorkbook();
             //创建 sheetname页名
            XSSFSheet sheet = workbook.createSheet("员工信息");
            sheet.setColumnWidth(3,20*256);//给第3列设置为20个字的宽度
            sheet.setColumnWidth(4,20*256);//给第4列设置为20个字的宽度
                //创建一行,下标从0开始
            XSSFRow row = sheet.createRow(0);
            //创建这行中的列,下标从0开始 (表头)
            XSSFCell cell = row.createCell(0);
             // 给cell 0下表赋值
            cell.setCellValue("姓名");
             //创建这行中的列,并给该列直接赋值
            row.createCell(1).setCellValue("年龄");
            row.createCell(2).setCellValue("性别");
            row.createCell(3).setCellValue("生日");
            row.createCell(4).setCellValue("手机号");
            // 设置表里内容
            row = sheet.createRow(1);
            row.createCell(0).setCellValue("T");
            row.createCell(1).setCellValue("保密");
            row.createCell(2).setCellValue("男");
            row.createCell(3).setCellValue("保密");
            row.createCell(4).setCellValue("12121212121");
    
            row = sheet.createRow(2);
            row.createCell(0).setCellValue("T");
            row.createCell(1).setCellValue("18");
            row.createCell(2).setCellValue("女");
            row.createCell(3).setCellValue("2000-01-01");
            row.createCell(4).setCellValue("12121212122");
            //设定 路径
            File file = new File("C:\\Users\\Administrator\\Desktop\\员工信息.xlsx");
            FileOutputStream stream = new FileOutputStream(file);
            // 需要抛异常
            workbook.write(stream);
             //关流
            stream.close();
        }
    
    
    }
    
    

    设置单元格的宽度

    sheet.setColumnWidth(x,20*256);//x=给第几列设置为20个字的宽度
    

    没有错误 就成功了
    在这里插入图片描述
    现在已经导出了

    在这里插入图片描述
    2003版本(包含2003)以前的扩展名为.xls需要用HSSFWorkbook类操作
    和 07基本相似 就是把XSSFWorkbook换成HSSFWorkbook
    后缀名改成 点xls

    import org.apache.poi.hssf.usermodel.HSSFCell;
    import org.apache.poi.hssf.usermodel.HSSFRow;
    import org.apache.poi.hssf.usermodel.HSSFSheet;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.xssf.usermodel.XSSFCell;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    import java.io.File;
    import java.io.FileOutputStream;
    import java.io.IOException;
    
    /**
     * Created by Administrator on 2019\3\9 0009.
     */
    public class PoiTest {
    
        public static void main(String[] args) throws IOException {
    
    
            //创建工作簿 类似于创建Excel文件
            HSSFWorkbook workbook=new HSSFWorkbook();
             //创建 sheetname页名
            HSSFSheet sheet = workbook.createSheet("员工信息");
                //创建一行,下标从0开始
            HSSFRow row = sheet.createRow(0);
            //创建这行中的列,下标从0开始 (表头)
            HSSFCell cell = row.createCell(0);
             // 给cell 0下表赋值
            cell.setCellValue("姓名");
             //创建这行中的列,并给该列直接赋值
            row.createCell(1).setCellValue("年龄");
            row.createCell(2).setCellValue("性别");
            row.createCell(3).setCellValue("生日");
            row.createCell(4).setCellValue("手机号");
            // 设置表里内容
            row = sheet.createRow(1);
            row.createCell(0).setCellValue("T");
            row.createCell(1).setCellValue("保密");
            row.createCell(2).setCellValue("男");
            row.createCell(3).setCellValue("保密");
            row.createCell(4).setCellValue("12121212121");
    
            row = sheet.createRow(2);
            row.createCell(0).setCellValue("T");
            row.createCell(1).setCellValue("18");
            row.createCell(2).setCellValue("女");
            row.createCell(3).setCellValue("2000-01-01");
            row.createCell(4).setCellValue("12121212122");
            //设定 路径
            File file = new File("C:\\Users\\Administrator\\Desktop\\员工信息.xls");
            FileOutputStream stream = new FileOutputStream(file);
            // 需要抛异常
            workbook.write(stream);
             //关流
            stream.close();
        }
    
    
    }
    
    

    导入

    import org.apache.poi.ss.usermodel.Row;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.ss.usermodel.Workbook;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.IOException;
    
    /**
         * Created by Administrator on 2019\3\9 0009.
         */
        public class PoiTest {
    
            public static void main(String[] args) throws IOException {
    
              import07();
            }
    
            public  static void import07() throws IOException {
                File file = new File("C:\\Users\\Administrator\\Desktop\\员工信息.xlsx");
                //获得该文件的输入流
                FileInputStream stream = new FileInputStream(file);
                // 多态  抛异常
                Workbook sheets = new XSSFWorkbook(stream);
                //获取一个工作表(sheet页),下标从0开始
                Sheet sheet = sheets.getSheetAt(0);
                for (int i = 1; i<=sheet.getLastRowNum() ; i++) {
                    
    
                // 获取行数
                Row row = sheet.getRow(i);
                // 获取单元格 取值
                String value1 = row.getCell(0).getStringCellValue();
                String value2 = row.getCell(1).getStringCellValue();
                String value3 = row.getCell(2).getStringCellValue();
                String value4 = row.getCell(3).getStringCellValue();
                String value5= row.getCell(4).getStringCellValue();
    
                    System.out.println(value1);
                    System.out.println(value2);
                    System.out.println(value3);
                    System.out.println(value4);
                    System.out.println(value5);
                }
    
    
                //关流
                sheets.close();
              stream.close();
            }
    
        }
    
    

    以导入
    在这里插入图片描述
    03版本与上面同理;

    展开全文
  • JAVA POI的使用

    万次阅读 多人点赞 2018-02-01 11:51:25
    下载地址 https://archive.apache.org/dist/poi/release/bin/ ...Poi-3.10-Final.jar (用于xls)Poi-ooxml-3.10-Final.jar (用于xlsx)Poi-ooxml-schemas-3.10.jarXmlbeans-2.30.jardom4j-1.6.1.jarp

    下载地址

    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)

    读doc

    public static String readWord(String name)
        {
            FileInputStream in;
            String text = null;
            try 
            {
                in = new FileInputStream(name);
                WordExtractor extractor = new WordExtractor(in);
                text = extractor.getText();
            } 
            catch (FileNotFoundException e) 
            {
                // TODO Auto-generated catch block
                e.printStackTrace();
            } catch (Exception e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            return text;
        }

    读docx

    public static String readDocx(String path)
        {
        //都是只能用String,不能用Stringbuffer,还不知道原因
            String text = null; 
            try {
                InputStream is = new FileInputStream("doc/aaa.docx");
                XWPFDocument doc = new XWPFDocument(is);  
                XWPFWordExtractor extractor = new XWPFWordExtractor(doc);  
                text = extractor.getText(); 
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
    
            return text;
        }

    读xls和xlsx

    private static Logger log = Logger.getLogger("client"); 
        public static String readXls(String path)
        {
            String text="";  
             try 
             {  
                  FileInputStream is =  new FileInputStream(path);
                  HSSFWorkbook excel=new HSSFWorkbook(is);  
                 //获取第一个sheet  
                 HSSFSheet sheet0=excel.getSheetAt(0);  
                 for (Iterator rowIterator=sheet0.iterator();rowIterator.hasNext();) 
                 {  
                     HSSFRow row=(HSSFRow) rowIterator.next();  
                     for (Iterator iterator=row.cellIterator();iterator.hasNext();) 
                     {  
                         HSSFCell cell=(HSSFCell) iterator.next();  
                         //根据单元的的类型 读取相应的结果  
                         if(cell.getCellType()==HSSFCell.CELL_TYPE_STRING) text+=cell.getStringCellValue()+"\t";  
                         else if(cell.getCellType()==HSSFCell.CELL_TYPE_NUMERIC) text+=cell.getNumericCellValue()+"\t";  
                         else if(cell.getCellType()==HSSFCell.CELL_TYPE_FORMULA) text+=cell.getCellFormula()+"\t";  
                     }  
                   text+="\n";  
                 }          
             } 
             catch (Exception e) 
             {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                    log.warn(e);
             }  
    
             return text; 
        }
        public static String readXlsx(String path)
        {
             String text="";  
             try 
             {  
                  OPCPackage pkg=OPCPackage.open(path);  
                  XSSFWorkbook excel=new XSSFWorkbook(pkg);  
                  //获取第一个sheet  
                  XSSFSheet sheet0=excel.getSheetAt(0);  
                  for (Iterator rowIterator=sheet0.iterator();rowIterator.hasNext();) 
                  {  
                      XSSFRow row=(XSSFRow) rowIterator.next();  
                      for (Iterator iterator=row.cellIterator();iterator.hasNext();) 
                      {  
                          XSSFCell cell=(XSSFCell) iterator.next();  
                          //根据单元的的类型 读取相应的结果  
                          if(cell.getCellType()==XSSFCell.CELL_TYPE_STRING) text+=cell.getStringCellValue()+"\t";  
                          else if(cell.getCellType()==XSSFCell.CELL_TYPE_NUMERIC) text+=cell.getNumericCellValue()+"\t";  
                          else if(cell.getCellType()==XSSFCell.CELL_TYPE_FORMULA) text+=cell.getCellFormula()+"\t";  
                      }  
                    text+="\n";  
                  }          
             } 
             catch (Exception e) 
             {  
                    // TODO Auto-generated catch block  
                    e.printStackTrace();  
                    log.warn(e);
             }  
    
             return text;  
        }

    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

    1. public class Test00
    2. {
    3.  public static void main(String[] args) throws IOException
    4.  {
    5.  String filePath="d:\\users\\lizw\\桌面\\POI\\sample.xls";//文件路径
    6.  HSSFWorkbook workbook = new HSSFWorkbook();//创建Excel文件(Workbook)
    7.  HSSFSheet sheet = workbook.createSheet();//创建工作表(Sheet)
    8. sheet = workbook.createSheet("Test");//创建工作表(Sheet)
    9.  FileOutputStream out = new FileOutputStream(filePath);
    10. workbook.write(out);//保存Excel文件
    11. out.close();//关闭文件流
    12.  System.out.println("OK!");
    13.  }
    14. }

    (2)创建单元格

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);// 创建行,从0开始
    3. HSSFCell cell = row.createCell(0);// 创建行的单元格,也是从0开始
    4. cell.setCellValue("李志伟");// 设置单元格内容
    5. row.createCell(1).setCellValue(false);// 设置单元格内容,重载
    6. row.createCell(2).setCellValue(new Date());// 设置单元格内容,重载
    7. row.createCell(3).setCellValue(12.345);// 设置单元格内容,重载

    (3)创建文档摘要信息

    1. workbook.createInformationProperties();//创建文档信息
    2. DocumentSummaryInformation dsi=workbook.getDocumentSummaryInformation();//摘要信息
    3. dsi.setCategory("类别:Excel文件");//类别
    4. dsi.setManager("管理者:李志伟");//管理者
    5. dsi.setCompany("公司:--");//公司
    6. SummaryInformation si = workbook.getSummaryInformation();//摘要信息
    7. si.setSubject("主题:--");//主题
    8. si.setTitle("标题:测试文档");//标题
    9. si.setAuthor("作者:李志伟");//作者
    10. si.setComments("备注:POI测试文档");//备注

    (4)创建批注

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFPatriarch patr = sheet.createDrawingPatriarch();
    3. HSSFClientAnchor anchor = patr.createAnchor(0, 0, 0, 0, 5, 1, 8,3);//创建批注位置
    4. HSSFComment comment = patr.createCellComment(anchor);//创建批注
    5. comment.setString(new HSSFRichTextString("这是一个批注段落!"));//设置批注内容
    6. comment.setAuthor("李志伟");//设置批注作者
    7. comment.setVisible(true);//设置批注默认显示
    8. HSSFCell cell = sheet.createRow(2).createCell(1);
    9. cell.setCellValue("测试");
    10. cell.setCellComment(comment);//把批注赋值给单元格

         创建批注位置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)创建页眉和页脚

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFHeader header =sheet.getHeader();//得到页眉
    3. header.setLeft("页眉左边");
    4. header.setRight("页眉右边");
    5. header.setCenter("页眉中间");
    6. HSSFFooter footer =sheet.getFooter();//得到页脚
    7. footer.setLeft("页脚左边");
    8. footer.setRight("页脚右边");
    9. footer.setCenter("页脚中间");

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

    1. HSSFHeader.tab &表名
    2. HSSFHeader.file &文件名
    3. HSSFHeader.startBold &粗体开始
    4. HSSFHeader.endBold &粗体结束
    5. HSSFHeader.startUnderline &下划线开始
    6. HSSFHeader.endUnderline &下划线结束
    7. HSSFHeader.startDoubleUnderline &双下划线开始
    8. HSSFHeader.endDoubleUnderline &双下划线结束
    9. HSSFHeader.time &时间
    10. HSSFHeader.date &日期
    11. HSSFHeader.numPages &总页面数
    12. HSSFHeader.page &当前页号

    3.Excel的单元格操作

    (1)设置格式

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row=sheet.createRow(0);
    3. //设置日期格式--使用Excel内嵌的格式
    4. HSSFCell cell=row.createCell(0);
    5. cell.setCellValue(new Date());
    6. HSSFCellStyle style=workbook.createCellStyle();
    7. style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
    8. cell.setCellStyle(style);
    9. //设置保留2位小数--使用Excel内嵌的格式
    10. cell=row.createCell(1);
    11. cell.setCellValue(12.3456789);
    12. style=workbook.createCellStyle();
    13. style.setDataFormat(HSSFDataFormat.getBuiltinFormat("0.00"));
    14. cell.setCellStyle(style);
    15. //设置货币格式--使用自定义的格式
    16. cell=row.createCell(2);
    17. cell.setCellValue(12345.6789);
    18. style=workbook.createCellStyle();
    19. style.setDataFormat(workbook.createDataFormat().getFormat("¥#,##0"));
    20. cell.setCellStyle(style);
    21. //设置百分比格式--使用自定义的格式
    22. cell=row.createCell(3);
    23. cell.setCellValue(0.123456789);
    24. style=workbook.createCellStyle();
    25. style.setDataFormat(workbook.createDataFormat().getFormat("0.00%"));
    26. cell.setCellStyle(style);
    27. //设置中文大写格式--使用自定义的格式
    28. cell=row.createCell(4);
    29. cell.setCellValue(12345);
    30. style=workbook.createCellStyle();
    31. style.setDataFormat(workbook.createDataFormat().getFormat("[DbNum2][$-804]0"));
    32. cell.setCellStyle(style);
    33. //设置科学计数法格式--使用自定义的格式
    34. cell=row.createCell(5);
    35. cell.setCellValue(12345);
    36. style=workbook.createCellStyle();
    37. style.setDataFormat(workbook.createDataFormat().getFormat("0.00E+00"));
    38. cell.setCellStyle(style);

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

    (2)合并单元格

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row=sheet.createRow(0);
    3. //合并列
    4. HSSFCell cell=row.createCell(0);
    5. cell.setCellValue("合并列");
    6. CellRangeAddress region=new CellRangeAddress(0, 0, 0, 5);
    7. sheet.addMergedRegion(region);
    8. //合并行
    9. cell=row.createCell(6);
    10. cell.setCellValue("合并行");
    11. region=new CellRangeAddress(0, 5, 6, 6);
    12. sheet.addMergedRegion(region);

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

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

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

    (3)单元格对齐

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

         水平对齐相关参数

    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 等

    1. HSSFCell cell=row.createCell(1);
    2. cell.setCellValue("设置边框");
    3. HSSFCellStyle style=workbook.createCellStyle();
    4. style.setBorderTop(HSSFCellStyle.BORDER_DOTTED);//上边框
    5. style.setBorderBottom(HSSFCellStyle.BORDER_THICK);//下边框
    6. style.setBorderLeft(HSSFCellStyle.BORDER_DOUBLE);//左边框
    7. style.setBorderRight(HSSFCellStyle.BORDER_SLANTED_DASH_DOT);//右边框
    8. style.setTopBorderColor(HSSFColor.RED.index);//上边框颜色
    9. style.setBottomBorderColor(HSSFColor.BLUE.index);//下边框颜色
    10. style.setLeftBorderColor(HSSFColor.GREEN.index);//左边框颜色
    11. style.setRightBorderColor(HSSFColor.PINK.index);//右边框颜色
    12. cell.setCellStyle(style);

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

    边框范例图

    对应的静态值

    HSSFCellStyle. BORDER_DOTTED

    HSSFCellStyle. BORDER_HAIR

    HSSFCellStyle. BORDER_DASH_DOT_DOT

    HSSFCellStyle. BORDER_DASH_DOT

    HSSFCellStyle. BORDER_DASHED

    HSSFCellStyle. BORDER_THIN

    HSSFCellStyle. BORDER_MEDIUM_DASH_DOT_DOT

    HSSFCellStyle. BORDER_SLANTED_DASH_DOT

    HSSFCellStyle. BORDER_MEDIUM_DASH_DOT

    HSSFCellStyle. BORDER_MEDIUM_DASHED

    HSSFCellStyle. BORDER_MEDIUM

    HSSFCellStyle. BORDER_THICK

    HSSFCellStyle. BORDER_DOUBLE

    (5)设置字体

    1. HSSFCell cell = row.createCell(1);
    2. cell.setCellValue("设置字体");
    3. HSSFCellStyle style = workbook.createCellStyle();
    4. HSSFFont font = workbook.createFont();
    5. font.setFontName("华文行楷");//设置字体名称
    6. font.setFontHeightInPoints((short)28);//设置字号
    7. font.setColor(HSSFColor.RED.index);//设置字体颜色
    8. font.setUnderline(FontFormatting.U_SINGLE);//设置下划线
    9. font.setTypeOffset(FontFormatting.SS_SUPER);//设置上标下标
    10. font.setStrikeout(true);//设置删除线
    11. style.setFont(font);
    12. cell.setCellStyle(style);

    下划线选项值:

    单下划线 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)背景和纹理

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

         图案样式及其对应的值:

    图案样式

    常量

    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)设置宽度和高度

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(1);
    3. HSSFCell cell = row.createCell(1);
    4. cell.setCellValue("123456789012345678901234567890");
    5. sheet.setColumnWidth(1, 31 * 256);//设置第一列的宽度是31个字符宽度
    6. 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)方法,例如:

    1. HSSFCell cell = row.createCell(1);
    2. cell.setCellValue(new Date());//设置日期数据
    3. System.out.println(DateUtil.isCellDateFormatted(cell));//输出:false
    4. HSSFCellStyle style =workbook.createCellStyle();
    5. style.setDataFormat(HSSFDataFormat.getBuiltinFormat("m/d/yy h:mm"));
    6. cell.setCellStyle(style);//设置日期样式
    7. System.out.println(DateUtil.isCellDateFormatted(cell));//输出:true

    4.使用Excel公式

    (1)基本计算

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. HSSFCell cell = row.createCell(0);
    4. cell.setCellFormula("2+3*4");//设置公式
    5. cell = row.createCell(1);
    6. cell.setCellValue(10);
    7. cell = row.createCell(2);
    8. cell.setCellFormula("A1*B1");//设置公式

    (2)SUM函数

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

    (3)日期函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFCellStyle style=workbook.createCellStyle();
    3. style.setDataFormat(workbook.createDataFormat().getFormat("yyyy-mm-dd"));
    4. HSSFRow row = sheet.createRow(0);
    5. Calendar date=Calendar.getInstance();//日历对象
    6. HSSFCell cell=row.createCell(0);
    7. date.set(2011,2, 7);
    8. cell.setCellValue(date.getTime());
    9. cell.setCellStyle(style);//第一个单元格开始时间设置完成
    10. cell=row.createCell(1);
    11. date.set(2014,4, 25);
    12. cell.setCellValue(date.getTime());
    13. cell.setCellStyle(style);//第一个单元格结束时间设置完成
    14. cell=row.createCell(3);
    15. cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"y\"),\"年\")");
    16. cell=row.createCell(4);
    17. cell.setCellFormula("CONCATENATE(DATEDIF(A1,B1,\"m\"),\"月\")");
    18. cell=row.createCell(5);
    19. 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)字符串相关函数

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

        

    以上代码中的公式说明:

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

     

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

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

    (5)IF函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. row.createCell(0).setCellValue(12);
    4. row.createCell(1).setCellValue(23);
    5. 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函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. row.createCell(0).setCellValue(57);
    4. row.createCell(1).setCellValue(89);
    5. row.createCell(2).setCellValue(56);
    6. row.createCell(3).setCellValue(67);
    7. row.createCell(4).setCellValue(60);
    8. row.createCell(5).setCellValue(73);
    9. row.createCell(7).setCellFormula("COUNTIF(A1:F1,\">=60\")");
    10. 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函数

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(0);
    3. row.createCell(0).setCellValue(0);
    4. row.createCell(1).setCellValue(59);
    5. row.createCell(2).setCellValue("不及格");
    6. row = sheet.createRow(1);
    7. row.createCell(0).setCellValue(60);
    8. row.createCell(1).setCellValue(69);
    9. row.createCell(2).setCellValue("及格");
    10. row = sheet.createRow(2);
    11. row.createCell(0).setCellValue(70);
    12. row.createCell(1).setCellValue(79);
    13. row.createCell(2).setCellValue("良好");
    14. row = sheet.createRow(3);
    15. row.createCell(0).setCellValue(80);
    16. row.createCell(1).setCellValue(100);
    17. row.createCell(2).setCellValue("优秀");
    18. row = sheet.createRow(4);
    19. row.createCell(0).setCellValue(75);
    20. row.createCell(1).setCellFormula("LOOKUP(A5,$A$1:$A$4,$C$1:$C$4)");
    21. 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)随机数函数

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

         以上代码中的公式说明:

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

    (9)获得公式的返回值

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

    5.使用图形

    (1)画线

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFPatriarch patriarch=sheet.createDrawingPatriarch();
    3. HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short)1, 0,(short)4, 4);
    4. HSSFSimpleShape line = patriarch.createSimpleShape(anchor);
    5. line.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);//设置图形类型
    6. line.setLineStyle(HSSFShape.LINESTYLE_SOLID);//设置图形样式
    7. 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)画矩形

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFPatriarch patriarch=sheet.createDrawingPatriarch();
    3. HSSFClientAnchor anchor = new HSSFClientAnchor(255,122,255, 122, (short)1, 0,(short)4, 3);
    4. HSSFSimpleShape rec = patriarch.createSimpleShape(anchor);
    5. rec.setShapeType(HSSFSimpleShape.OBJECT_TYPE_RECTANGLE);
    6. rec.setLineStyle(HSSFShape.LINESTYLE_DASHGEL);//设置边框样式
    7. rec.setFillColor(255, 0, 0);//设置填充色
    8. rec.setLineWidth(25400);//设置边框宽度
    9. rec.setLineStyleColor(0, 0, 255);//设置边框颜色

    (3)画圆形

         更改上例的代码如下:

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

    (4)画Grid

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

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. HSSFRow row = sheet.createRow(2);
    3. row.createCell(1);
    4. row.setHeightInPoints(240);
    5. sheet.setColumnWidth(2, 9000);
    6. int linesCount = 20;
    7. HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
    8. //因为HSSFClientAnchor中dx只能在0-1023之间,dy只能在0-255之间,这里采用比例的方式
    9. double xRatio = 1023.0 / (linesCount * 10);
    10. double yRatio = 255.0 / (linesCount * 10);
    11. // 画竖线
    12. int x1 = 0;
    13. int y1 = 0;
    14. int x2 = 0;
    15. int y2 = 200;
    16. for (int i = 0; i < linesCount; i++)
    17. {
    18.  HSSFClientAnchor a2 = new HSSFClientAnchor();
    19. a2.setAnchor((short) 2, 2, (int) (x1 * xRatio),
    20.  (int) (y1 * yRatio), (short) 2, 2, (int) (x2 * xRatio),
    21.  (int) (y2 * yRatio));
    22.  HSSFSimpleShape shape2 = patriarch.createSimpleShape(a2);
    23. shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
    24. x1 += 10;
    25. x2 += 10;
    26. }
    27. // 画横线
    28. x1 = 0;
    29. y1 = 0;
    30. x2 = 200;
    31. y2 = 0;
    32. for (int i = 0; i < linesCount; i++)
    33. {
    34.  HSSFClientAnchor a2 = new HSSFClientAnchor();
    35. a2.setAnchor((short) 2, 2, (int) (x1 * xRatio),
    36.  (int) (y1 * yRatio), (short) 2, 2, (int) (x2 * xRatio),
    37.  (int) (y2 * yRatio));
    38.  HSSFSimpleShape shape2 = patriarch.createSimpleShape(a2);
    39. shape2.setShapeType(HSSFSimpleShape.OBJECT_TYPE_LINE);
    40. y1 += 10;
    41. y2 += 10;
    42. }

     

    (5)插入图片

    1. HSSFSheet sheet = workbook.createSheet("Test");// 创建工作表(Sheet)
    2. FileInputStream stream=newFileInputStream("d:\\POI\\Apache.gif");
    3. byte[] bytes=new byte[(int)stream.getChannel().size()];
    4. stream.read(bytes);//读取图片到二进制数组
    5. int pictureIdx = workbook.addPicture(bytes,HSSFWorkbook.PICTURE_TYPE_JPEG);
    6. HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
    7. HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short)0, 0, (short)5, 5);
    8. HSSFPicture pict = patriarch.createPicture(anchor,pictureIdx);
    9. //pict.resize();//自动调节图片大小,图片位置信息可能丢失

    (6)从Excel文件提取图片

    1. InputStream inp = new FileInputStream(filePath);
    2. HSSFWorkbook workbook = new HSSFWorkbook(inp);//读取现有的Excel文件
    3. List<HSSFPictureData> pictures = workbook.getAllPictures();
    4. for(int i=0;i<pictures.size();i++)
    5. {
    6.  HSSFPictureData pic=pictures.get(i);
    7.  String ext = pic.suggestFileExtension();
    8.  if (ext.equals("png"))//判断文件格式
    9.  {
    10.  FileOutputStream png=newFileOutputStream("d:\\POI\\Apache.png");
    11. png.write(pic.getData());
    12. png.close();//保存图片
    13.  }
    14. }

    6.Excel表操作

    (1)设置默认工作表

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. workbook.createSheet("Test2");// 创建工作表(Sheet)
    5. workbook.createSheet("Test3");// 创建工作表(Sheet)
    6. workbook.setActiveSheet(2);//设置默认工作表

    (2)重命名工作表

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. workbook.createSheet("Test2");// 创建工作表(Sheet)
    5. workbook.createSheet("Test3");// 创建工作表(Sheet)
    6. workbook.setSheetName(2, "1234");//重命名工作表

    (3)调整表单显示比例

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. HSSFSheet sheet1= workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. HSSFSheet sheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. HSSFSheet sheet3=workbook.createSheet("Test2");// 创建工作表(Sheet)
    5. sheet1.setZoom(1,2);//50%显示比例
    6. sheet2.setZoom(2,1);//200%显示比例
    7. sheet3.setZoom(1,10);//10%显示比例

    (4)显示/隐藏网格线

    1. HSSFWorkbook workbook = new HSSFWorkbook();// 创建Excel文件(Workbook)
    2. HSSFSheet sheet1= workbook.createSheet("Test0");// 创建工作表(Sheet)
    3. HSSFSheet sheet2=workbook.createSheet("Test1");// 创建工作表(Sheet)
    4. sheet1.setDisplayGridlines(false);//隐藏Excel网格线,默认值为true
    5. sheet2.setGridsPrinted(true);//打印时显示网格线,默认值为false

    (5)遍历Sheet

    1. String filePath = "d:\\users\\lizw\\桌面\\POI\\sample.xls";
    2. FileInputStream stream = new FileInputStream(filePath);
    3. HSSFWorkbook workbook = new HSSFWorkbook(stream);//读取现有的Excel
    4. HSSFSheet sheet= workbook.getSheet("Test0");//得到指定名称的Sheet
    5. for (Row row : sheet)
    6. {
    7.  for (Cell cell : row)
    8.  {
    9.  System.out.print(cell + "\t");
    10.  }
    11.  System.out.println();
    12. }

    7.Excel行列操作

    (1)组合行、列

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

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

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

    (2)锁定列

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

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

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

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

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

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

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

    (3)上下移动行

    1. FileInputStream stream = new FileInputStream(filePath);
    2. HSSFWorkbook workbook = new HSSFWorkbook(stream);
    3. HSSFSheet sheet = workbook.getSheet("Test0");
    4. sheet.shiftRows(2, 4, 2);//把第3行到第4行向下移动两行

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

              startRow:需要移动的起始行;

              endRow:需要移动的结束行;

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

     

    8.Excel的其他功能

    (1)设置密码
    1. HSSFSheet sheet= workbook.createSheet("Test0");// 创建工作表(Sheet)
    2. HSSFRow row=sheet.createRow(1);
    3. HSSFCell cell=row.createCell(1);
    4. cell.setCellValue("已锁定");
    5. HSSFCellStyle locked = workbook.createCellStyle();
    6. locked.setLocked(true);//设置锁定
    7. cell.setCellStyle(locked);
    8. cell=row.createCell(2);
    9. cell.setCellValue("未锁定");
    10. HSSFCellStyle unlocked = workbook.createCellStyle();
    11. unlocked.setLocked(false);//设置不锁定
    12. cell.setCellStyle(unlocked);
    13. sheet.protectSheet("password");//设置保护密码
    (2)数据有效性
    1. HSSFSheet sheet= workbook.createSheet("Test0");// 创建工作表(Sheet)
    2. HSSFRow row=sheet.createRow(0);
    3. HSSFCell cell=row.createCell(0);
    4. cell.setCellValue("日期列");
    5. CellRangeAddressList regions = new CellRangeAddressList(1, 65535,0, 0);//选定一个区域
    6. DVConstraint constraint = DVConstraint.createDateConstraint(DVConstraint . OperatorType . BETWEEN , "1993-01-01" ,"2014-12-31" , "yyyy-MM-dd" );
    7. HSSFDataValidation dataValidate = new HSSFDataValidation(regions,constraint);
    8. dataValidate.createErrorBox("错误", "你必须输入一个时间!");
    9. sheet.addValidationData(dataValidate);

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

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

    (3)生成下拉式菜单

    1. CellRangeAddressList regions = new CellRangeAddressList(0, 65535,0, 0);
    2. DVConstraint constraint =DVConstraint.createExplicitListConstraint(new String[] { "C++","Java", "C#" });
    3. HSSFDataValidation dataValidate = new HSSFDataValidation(regions,constraint);
    4. sheet.addValidationData(dataValidate);

    (4)打印基本设置

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

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

    (5)超链接

    1. HSSFSheet sheet = workbook.createSheet("Test0");
    2. CreationHelper createHelper = workbook.getCreationHelper();
    3. // 关联到网站
    4. Hyperlink link =createHelper.createHyperlink(Hyperlink.LINK_URL);
    5. link.setAddress("http://poi.apache.org/");
    6. sheet.createRow(0).createCell(0).setHyperlink(link);
    7. // 关联到当前目录的文件
    8. link = createHelper.createHyperlink(Hyperlink.LINK_FILE);
    9. link.setAddress("sample.xls");
    10. sheet.createRow(0).createCell(1).setHyperlink(link);
    11. // e-mail 关联
    12. link = createHelper.createHyperlink(Hyperlink.LINK_EMAIL);
    13. link.setAddress("mailto:poi@apache.org?subject=Hyperlinks");
    14. sheet.createRow(0).createCell(2).setHyperlink(link);
    15. //关联到工作簿中的位置
    16. link = createHelper.createHyperlink(Hyperlink.LINK_DOCUMENT);
    17. link.setAddress("'Test0'!C3");//Sheet名为Test0的C3位置
    18. sheet.createRow(0).createCell(3).setHyperlink(link);

    9.POI对Word的基本操作

    (1)POI操作Word简介

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

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

    1. XWPFDocument doc = new XWPFDocument();// 创建Word文件
    2. XWPFParagraph p = doc.createParagraph();// 新建一个段落
    3. p.setAlignment(ParagraphAlignment.CENTER);// 设置段落的对齐方式
    4. p.setBorderBottom(Borders.DOUBLE);//设置下边框
    5. p.setBorderTop(Borders.DOUBLE);//设置上边框
    6. p.setBorderRight(Borders.DOUBLE);//设置右边框
    7. p.setBorderLeft(Borders.DOUBLE);//设置左边框
    8. XWPFRun r = p.createRun();//创建段落文本
    9. r.setText("POI创建的Word段落文本");
    10. r.setBold(true);//设置为粗体
    11. r.setColor("FF0000");//设置颜色
    12. = doc.createParagraph();// 新建一个段落
    13. = p.createRun();
    14. r.setText("POI读写Excel功能强大、操作简单。");
    15. XWPFTable table= doc.createTable(3, 3);//创建一个表格
    16. table.getRow(0).getCell(0).setText("表格1");
    17. table.getRow(1).getCell(1).setText("表格2");
    18. table.getRow(2).getCell(2).setText("表格3");
    19. FileOutputStream out = newFileOutputStream("d:\\POI\\sample.doc");
    20. doc.write(out);
    21. out.close();

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

    1. FileInputStream stream = newFileInputStream("d:\\POI\\sample.doc");
    2. XWPFDocument doc = new XWPFDocument(stream);// 创建Word文件
    3. for(XWPFParagraph p : doc.getParagraphs())//遍历段落
    4. {
    5.  System.out.print(p.getParagraphText());
    6. }
    7. for(XWPFTable table : doc.getTables())//遍历表格
    8. {
    9.  for(XWPFTableRow row : table.getRows())
    10.  {
    11.  for(XWPFTableCell cell : row.getTableCells())
    12.  {
    13.  System.out.print(cell.getText());
    14.  }
    15.  }
    16. }

    展开全文
  • 关于表格导入导出,市面上比较知名的开源就是 Apache 的POI 和 阿里巴巴的 EasyExcel了。EasyExcel 也是对 POI 的改进和封装, 更加好用。下面通过一些 demo 学习如何使用这两个开源组件。这两个组件都不难,多看...
  • POI和EasyExcel

    2020-09-13 15:50:24
    操作Excel目前比较流行的是POI(Apache)和easyExcel(阿里巴巴) 一:Apache POI 官网:https://poi.apache.org/ POI提供API给java程序,使用java程序对Office的读和写的功能。 POI提供了些基本对象: 比如: *...
  • POI&easyExcel

    2020-05-19 18:32:57
    POI 和 easyExcel 讲解 将用户信息导出为excel表格(导出数据....) 将Excel表中的信息录入到网站数据库(习题上传....) 开发中经常会设计到excel的处理,如导出Excel,导入Excel到数据库中! 操作Excel目前比较...
  • POI和EasyExcel-你还在为导入导出数据苦恼吗?

    千次阅读 多人点赞 2020-08-24 11:50:36
    在开发中经常会涉及到excel的处理,比如导出用户信息为excel表格、打印报表、月销售情况、成绩单等等(导出数据),还有将excel的信息录入到网站数据库等(导入数据),我们不可能手动操作,所以介绍Apache的POI和...
  • Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读 和写的功能。 HSSF - 提供读写Microsoft Excel格式档案的功能。(03版) XSSF - 提供读写Microsoft Excel ...
  • java Poi基础(一)

    万次阅读 2019-01-13 17:25:14
    1Poi简介: 1.1什么是poi: Apache POI [1] 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能。POI为“Poor Obfuscation Implementation”的首...
  • poi是什么?

    万次阅读 2016-11-09 22:00:18
    这个时候就用到了我们的poi。  通俗的讲,poi就是批量的操作文件或数据的导入以及导出。批量的操作,哈!听着就爽!看起来挺牛的!可能就有很多人会说,这会不会很难?我在这里可以明确的告诉大家,这是一项既简单...
  • [JAVA]POI各Jar包的作用

    万次阅读 多人点赞 2014-09-04 16:03:11
    目前POI的最新发布版本是3.10_FINAL.该版本保护的jar包有: Maven artifactId Prerequisites JAR poi commons-logging, commons-codec, log4j poi-version-yyyymmdd.jar poi-...
  • maven导入poi配置

    万次阅读 2016-05-05 17:11:40
    org.apache.poi  poi-ooxml  3.9
  • poi的各个版本

    万次阅读 2015-12-22 15:17:10
    目前POI的最新发布版本是3.10_FINAL.该版本保护的jar包有: Maven artifactId Prerequisites JAR poi commons-logging, commons-codec, log4j poi-version-yyyymmdd.jar poi...
  • 通过maven引入POI

    万次阅读 2018-05-25 09:42:57
    org.apache.poi&lt;/groupId&gt; &lt;artifactId&gt;poi&lt;/artifactId&gt; &lt;version&gt;3.17&lt;/version&gt; &lt;/dependency&gt; 则无XSSF
  • poi 单元格内容换行

    万次阅读 2016-02-23 10:43:44
    1.设置单元格内容自动换行HSSFCellStyle cellStyle=workbook.createCellStyle(); cellStyle.setWrapText(true); cell.setCellStyle(cellStyle); 2....// 文本中添加换行标志 String cnt = "cnt" + "\r\n
  • 最近项目需要导出Excel表功能,研究了好多,最后决定用阿帕奇的POI;  使用maven导入jar包时,发现POI有好多jar包,顿时不知应该导入那个,如果全部导入,使用应该没问题,但个人癖好是,用的导入,多余的不留,所以,又去官网...
  • 再向POI导出的表格中填出数据时,由于数据过多,一行显示不全数据,这时候想自动调整行高 ?怎么办?或者说怎么让数据显示完全?
  • POI各种jar包作用和导入

    万次阅读 2016-05-24 13:52:01
    目前POI的最新发布版本是3.10_FINAL.该版本保护的jar包有: Maven artifactId Prerequisites JAR poi commons-logging, commons-codec, log4j poi-version-yyyymmdd.jar poi-scratchpad
1 2 3 4 5 ... 20
收藏数 84,200
精华内容 33,680
关键字:

poi