有的时候,我们需要Excel中的数据,通过一个图画,可视化的表现出来。 那么这个时候,应该如何做呢?现在就借花献佛,以Apache POI自己提供的一个例子为例,给大家演示一下POI的API 如何画图的。下面是一个最终的效果图。然后分别给大家解释每段代码的作用和意义。

代码如下,

  1. import java.io.FileOutputStream;
  2. import org.apache.poi.ss.usermodel.*;
  3. import org.apache.poi.ss.util.*;
  4. import org.apache.poi.ss.usermodel.charts.*;
  5. import org.apache.poi.xssf.usermodel.XSSFWorkbook;
  6. /**
  7. * Illustrates how to create a simple scatter chart.
  8. *
  9. * @author Roman Kashitsyn
  10. */
  11. public class ScatterChart {
  12. public static void main(String[] args) throws Exception {
  13. Workbook wb = new XSSFWorkbook();
  14. Sheet sheet = wb.createSheet("Sheet 1");
  15. final int NUM_OF_ROWS = 3;
  16. final int NUM_OF_COLUMNS = 10;
  17. // Create a row and put some cells in it. Rows are 0 based.
  18. Row row;
  19. Cell cell;
  20. for (int rowIndex = 0; rowIndex < NUM_OF_ROWS; rowIndex++) {
  21. row = sheet.createRow((short) rowIndex);
  22. for (int colIndex = 0; colIndex < NUM_OF_COLUMNS; colIndex++) {
  23. cell = row.createCell((short) colIndex);
  24. cell.setCellValue(colIndex * (rowIndex + 1));
  25. }
  26. }
  27. Drawing drawing = sheet.createDrawingPatriarch();
  28. ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 5, 10, 15);
  29. Chart chart = drawing.createChart(anchor);
  30. ChartLegend legend = chart.getOrCreateLegend();
  31. legend.setPosition(LegendPosition.TOP_RIGHT);
  32. ScatterChartData data = chart.getChartDataFactory().createScatterChartData();
  33. ValueAxis bottomAxis = chart.getChartAxisFactory().createValueAxis(AxisPosition.BOTTOM);
  34. ValueAxis leftAxis = chart.getChartAxisFactory().createValueAxis(AxisPosition.LEFT);
  35. leftAxis.setCrosses(AxisCrosses.AUTO_ZERO);
  36. ChartDataSource<Number> xs = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(0, 0, 0, NUM_OF_COLUMNS - 1));
  37. ChartDataSource<Number> ys1 = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(1, 1, 0, NUM_OF_COLUMNS - 1));
  38. ChartDataSource<Number> ys2 = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(2, 2, 0, NUM_OF_COLUMNS - 1));
  39. data.addSerie(xs, ys1);
  40. data.addSerie(xs, ys2);
  41. chart.plot(data, bottomAxis, leftAxis);
  42. // Write the output to a file
  43. FileOutputStream fileOut = new FileOutputStream("ooxml-scatter-chart.xlsx");
  44. wb.write(fileOut);
  45. fileOut.close();
  46. }
  47. }

下面逐一来分解:

1.下面的代码新建一个工作簿和工作表单的对象

  1. Workbook wb = new XSSFWorkbook();
  2. Sheet sheet = wb.createSheet("Sheet 1");

2.下面这段代码是用生成初始化数据的,总共的数据有3行10列。

  1. final int NUM_OF_ROWS = 3;
  2. final int NUM_OF_COLUMNS = 10;
  3. // Create a row and put some cells in it. Rows are 0 based.
  4. Row row;
  5. Cell cell;
  6. for (int rowIndex = 0; rowIndex < NUM_OF_ROWS; rowIndex++) {
  7. row = sheet.createRow((short) rowIndex);
  8. for (int colIndex = 0; colIndex < NUM_OF_COLUMNS; colIndex++) {
  9. cell = row.createCell((short) colIndex);
  10. cell.setCellValue(colIndex * (rowIndex + 1));
  11. }
  12. }

3. 下面这段代码设置了画图的区域:从第5行开始,到15行结束;总共占用10列

  1. Drawing drawing = sheet.createDrawingPatriarch();
  2. ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 5, 10, 15);

4.创建一个离散图的坐标系

  1. Chart chart = drawing.createChart(anchor);
  2. ChartLegend legend = chart.getOrCreateLegend();
  3. legend.setPosition(LegendPosition.TOP_RIGHT);
  4. ScatterChartData data = chart.getChartDataFactory().createScatterChartData();
  5. ValueAxis bottomAxis = chart.getChartAxisFactory().createValueAxis(AxisPosition.BOTTOM);
  6. ValueAxis leftAxis = chart.getChartAxisFactory().createValueAxis(AxisPosition.LEFT);
  7. leftAxis.setCrosses(AxisCrosses.AUTO_ZERO);

5.往离散图上填充数据

  1. ChartDataSource<Number> xs = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(0, 0, 0, NUM_OF_COLUMNS - 1));
  2. ChartDataSource<Number> ys1 = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(1, 1, 0, NUM_OF_COLUMNS - 1));
  3. ChartDataSource<Number> ys2 = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(2, 2, 0, NUM_OF_COLUMNS - 1));
  4. data.addSerie(xs, ys1);
  5. data.addSerie(xs, ys2);

其中,下面的方法定义

  1. DataSources.fromNumericCellRange(sheet, new CellRangeAddress(0, 0, 0, NUM_OF_COLUMNS - 1));

如下,

  1. public static ChartDataSource<Number> fromNumericCellRange(Sheet sheet, CellRangeAddress cellRangeAddress)

从上面可以看出,其实填充数据的关键方法是,

  1. <pre name="code" class="java">new CellRangeAddress(0, 0, 0, NUM_OF_COLUMNS - 1)

那么这个方式是如何定义的呢?

  1. public CellRangeAddress(int firstRow, int lastRow, int firstCol, int lastCol)

从上面可以看出,其让我们制定数据是从那一行开始的,那一行结束的,那一列开始的,那一列结束。

在上面的代码的5句话中,分别把第1行的1到10列做为基准,然后把第2行的1到10列做一个比较,画出曲线系列1

把第1行的1到10列做为基准,然后把第3行的1到10列做一个比较,画出曲线系列2

6. 开始画图

  1. chart.plot(data, bottomAxis, leftAxis);

7. 保存成一个Excel文件

    1. FileOutputStream fileOut = new FileOutputStream("ooxml-scatter-chart.xlsx");
    2. wb.write(fileOut);
    3. fileOut.close();

如何用Apache POI操作Excel文件-----如何用Apache POI 画一个离散图的更多相关文章

  1. java使用POI操作excel文件,实现批量导出,和导入

    一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Exc ...

  2. java使用Apache POI操作excel文件

    官方介绍 HSSF is the POI Project's pure Java implementation of the Excel '97(-2007) file format. XSSF is ...

  3. Java使用POI操作Excel文件

    1.简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式文件读和写的功能. 2.依赖的jar包 <!-- ex ...

  4. 如何用Apache POI操作Excel文件-----如何对一个单元格加注解?

    有的时候,我们需要通过操作Apache POI,在生成Cell数据的同时,能对其生成的Cell,加上注解(comments),类似于下面的. 那么对于这种情况,我们的代码应该如何写呢? 借花献佛,我就 ...

  5. 如何用Apache POI操作Excel文件-----如何在已有的Excel文件中插入一行新的数据?

    在POI的第一节入门中,我们提供了两个简单的例子,一个是如何用Apache POI新建一个工作薄,另外一个例子是,如果用Apache POI新建一个工作表.那么在这个章节里面,我将会给大家演示一下,如 ...

  6. (6) 如何用Apache POI操作Excel文件-----POI-3.10的一个和注解(comment)相关的另外一个bug

    如果POI-3.10往一个工作表(sheet)里面插入数据的话,需要注意了,其有一个不太被容易发现的bug. 被插入的工作表(sheet)里面的单元格没有包含任何的注解(comment)的时候,插入一 ...

  7. 使用Apache POI操作Excel文件---在已有的Excel文件中插入一行新的数据

    package org.test; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundEx ...

  8. [转载]Java操作Excel文件的两种方案

    微软在桌面系统上的成功,令我们不得不大量使用它的办公产品,如:Word,Excel.时至今日,它的源代码仍然不公开已封锁了我们的进一步应用和开发.在我们实际开发企业办公系统的过程中,常常有客户这样子要 ...

  9. 使用POI操作Excel时对事先写入模板的公式强制执行

    场景:POI读取Excel模板. 当使用POI操作Excel时,发现由POI生成的公式能够在打开Excel是被执行, 而事先手工写入Excel模板文件的公式则不自动被调用,必须手动双击该Cell才能生 ...

随机推荐

  1. CSS鼠标样式整理

    鼠标样式的标签: cursor:*;  //该属性定义了鼠标指针放在一个元素边界范围内时所用的光标形状: 鼠标样式: 值 描述 url 需使用的自定义光标的 URL. 注释:请在此列表的末端始终定义一 ...

  2. protostuff简单应用

    protobuf是谷歌推出的与语言无关.平台无关的通信协议,一个对象经过protobuf序列化后将变成二进制格式的数据,所以他可读性差,但换来的是占用空间小,速度快.居网友测试,它的序列化效率是xml ...

  3. Android下利用Bitmap切割图片

    在自己自定义的一个组件中由于需要用图片显示数字编号,而当前图片就只有一张,上面有0-9是个数字,于是不得不考虑将其中一个个的数字切割下来,需要显示什么数字,只需要组合一下就好了. 下面是程序的关键代码 ...

  4. struts2 标签问题----escape="false" 这个属性

    1.在编程过程中,会遇到这个动西,escape="false" eg: <s:fielderror escape="false"/>-------& ...

  5. iOS及时log日志查看工具 (iConsole)

    github下载地址:https://github.com/nicklockwood/iConsole 偶然看到的一个iOS及时log日志查看工具,通过该工具,我们可以在任何想看日志的时候,通过手势呼 ...

  6. zabbix_agent端 key

    root@(none):/etc/zabbix/zabbix_agentd.conf.d# grep -v "^$" /etc/zabbix/zabbix_agentd.conf| ...

  7. ytu 2011: C语言实验——找中间数(水题)

    2011: C语言实验——找中间数 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 212  Solved: 122[Submit][Status][Web ...

  8. Android下拉刷新完全解析,教你如何一分钟实现下拉刷新功能 (转)

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/9255575 最 近项目中需要用到ListView下拉刷新的功能,一开始想图省事,在 ...

  9. Web开发中运行环境的配置:(Tomcat7.0.59)和开发环境的配置

    第一部分:运行环境的配置 1.下载压缩包,解压即可 2.配置系统变量JAVA_HOME为jdk的安装路径 3.如有需要修改端口号,比如8080已被占用的时候,可以将其改为9080等 apache-to ...

  10. 【JSP jstl c标签】使用c:foreach 报错(警告)”test does not support runtime expressions“

    后台封装的数据是个list,传递给前台,显示如下: <c:forEach items="${userInfo}" var="user"> 用户Nam ...