首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用Apache在excel中创建图形

Apache是一个开源的软件基金会,提供了许多开源软件项目,其中包括Apache POI。Apache POI是一个用于操作Microsoft Office格式文件的Java库,可以用于在Excel中创建图形。

在Excel中创建图形可以通过Apache POI的XSSF(XML Spreadsheet Format)类来实现。下面是一个示例代码,展示了如何使用Apache POI在Excel中创建一个柱状图:

代码语言:java
复制
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.*;

public class ExcelChartExample {
    public static void main(String[] args) throws Exception {
        // 创建工作簿和工作表
        Workbook workbook = new XSSFWorkbook();
        Sheet sheet = workbook.createSheet("Chart");

        // 创建数据行
        Row row1 = sheet.createRow(0);
        row1.createCell(0).setCellValue("Category");
        row1.createCell(1).setCellValue("Value 1");
        row1.createCell(2).setCellValue("Value 2");

        Row row2 = sheet.createRow(1);
        row2.createCell(0).setCellValue("A");
        row2.createCell(1).setCellValue(10);
        row2.createCell(2).setCellValue(20);

        Row row3 = sheet.createRow(2);
        row3.createCell(0).setCellValue("B");
        row3.createCell(1).setCellValue(15);
        row3.createCell(2).setCellValue(25);

        // 创建图表
        Drawing<?> drawing = sheet.createDrawingPatriarch();
        ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 4, 1, 10, 15);
        Chart chart = drawing.createChart(anchor);
        ChartLegend legend = chart.getOrCreateLegend();
        legend.setPosition(LegendPosition.RIGHT);

        LineChartData data = chart.getChartDataFactory().createLineChartData();

        // 创建数据系列
        ChartAxis bottomAxis = chart.getChartAxisFactory().createCategoryAxis(AxisPosition.BOTTOM);
        ChartAxis leftAxis = chart.getChartAxisFactory().createValueAxis(AxisPosition.LEFT);
        leftAxis.setCrosses(AxisCrosses.AUTO_ZERO);

        ChartDataSource<Number> xs = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(1, 2, 0, 0));
        ChartDataSource<Number> ys1 = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(1, 2, 1, 1));
        ChartDataSource<Number> ys2 = DataSources.fromNumericCellRange(sheet, new CellRangeAddress(1, 2, 2, 2));

        data.addSeries(xs, ys1);
        data.addSeries(xs, ys2);

        chart.plot(data, bottomAxis, leftAxis);

        // 保存Excel文件
        try (FileOutputStream fileOut = new FileOutputStream("chart_example.xlsx")) {
            workbook.write(fileOut);
        }

        System.out.println("Excel文件创建成功!");
    }
}

这段代码使用Apache POI创建了一个Excel文件,并在其中创建了一个柱状图。首先,创建了一个工作簿和一个工作表,然后在工作表中创建了数据行,包括类别和数值。接下来,使用createDrawingPatriarch()方法创建了一个绘图对象,并使用createAnchor()方法创建了一个锚点,用于确定图表的位置和大小。然后,使用createChart()方法创建了一个图表对象,并使用getOrCreateLegend()方法创建了一个图例对象,并设置其位置。接着,使用createLineChartData()方法创建了一个图表数据对象,并使用createCategoryAxis()createValueAxis()方法创建了横轴和纵轴对象。然后,使用fromNumericCellRange()方法创建了数据系列的数据源,并使用addSeries()方法将数据系列添加到图表数据对象中。最后,使用plot()方法将图表数据对象、横轴和纵轴绘制到图表中。最后,使用write()方法将工作簿保存为Excel文件。

这只是一个简单的示例,你可以根据需要调整代码来创建不同类型的图表。另外,腾讯云提供了云计算相关的产品,如云服务器、云数据库、云存储等,你可以根据具体需求选择适合的产品。你可以访问腾讯云官网(https://cloud.tencent.com/)了解更多关于腾讯云产品的信息。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Excel创建悬浮图

标签:Excel图表技巧 有时候,我们想将图表的数据列悬浮呈现。本文介绍如何实现这样效果的技巧。 原始数据及想要创建的图表如下图1所示。...图1 步骤1:根据原始数据,整理用于创建图表的数据,如下图2所示。一个名为“隐藏”的列,计算出悬浮的高度,也就是前面显示的柱状的高度之后;一个名为“显示”的列,即绘制的可见柱状的高度。...图2 步骤2:选择新数据区域,单击功能区“插入”选项卡“图表”组的“插入柱形图或条形图——堆积柱形图”,得到的图表如下图3所示。...步骤4:单击功能区“插入”选项卡的“插图——形状——箭头符号”,图表附近绘制一个向上的箭头形状。 步骤5:单击选取箭头形状,按Ctrl+C复制箭头。...步骤6:单击图表可见的柱形,这将选择所有柱形。按Ctrl+V进行粘贴,箭头将替换柱形。结果如下图5所示。 图5

59750

Excel创建瀑布图

标签:Excel图表技巧,瀑布图 Excel很容易创建瀑布图,因为自Excel 2016就推出了瀑布图。然而,改变瀑布颜色稍微有点困难。...刚开始选择数据并插入瀑布图时,没有被标记为“汇总”列,这意味着所有列都将是浮动的。我们可以两次单击应该为总计的列,这将选择该列。然后,该列上单击鼠标右键,选择“设置为汇总”,如下图1所示。...图1 从图1可以观察到,可以更改每个点的填充和轮廓。如果希望瀑布以橙色表示正,灰色表示负,可能会右键单击每一列并手动更改颜色。这是一种“笨”办法!并且,如果数据从正变为负,则颜色不会改变。...此时,可以单击功能区“页面布局”选项卡,再单击“主题”组“颜色”下拉列表,选取其底部的“自定义颜色”。其中,着色1用于增加,着色2用于减少,着色3用于汇总。改变这三种颜色,瀑布图中的颜色就会改变。

60730
  • Excel创建条件格式图表

    标签:Excel图表技巧 问题:希望图表对于比率为90或以上的呈现绿色,70至90的呈现黄色,低于70的呈现红色。可以图表设置条件格式吗?如下图1所示。 图1 示例数据如下图2所示。...单元格E2输入公式: =IF(B2<H2,B2,NA()) 向下拉复制公式至该列所有数据单元格。...单元格F2输入公式: =IF(AND(B2>=H2,B2<I2),B2,NA()) 向下拉复制公式至该列所有数据单元格。...单元格G2输入公式: =IF(B2>I2,B2,NA()) 向下拉复制公式至该列所有数据单元格。 最终整理后的数据如下图3所示。 图3 更清楚一些,每个单元格的公式如下图4所示。...图4 选择单元格区域D1:G8,创建堆积柱形图。然后,选择每个系列,使用“设置数据系列格式——填充”来选择正确的颜色。最终的结果如上文图1所示。

    38040

    ASP.NET随意创建图形信息

    如果没有一个外部组件的支持,ASP是不能动态创建图形的,不管它是一个图表,一个横幅或仅仅是一个图形计数器。可喜的是,这一点ASP.NET改变了。...用命令行程序创建图形   讨论一大堆ASP.NET代码之前,我们先执行一个简单的命令行程序做一个测试,然后使用这些源代码作为 ASP.NET 脚本的基础。...计算结束之后,再废弃这个虚拟图形并生成一个适当尺寸的图形。   源代码中有一点很有趣,这就是 Graphics 对象。要创建一个位图时,这个对象做什么呢?奥妙在于:这是可以向其中绘图的上下文环境。...我们可以屏幕上、打印机上和内存中使用一个图形上下文环境,准确地说就是一个位图。图形的上下文环境使我们能够在任何设备上进行绘图操作,甚至是虚拟设备上。  ...接着,DrawString将文本 "Hello World"按照规格输出到一个白色背景的矩形( FillRectangle创建的)图形完成后,将其保存在磁盘上。

    1.2K20

    VBA通用代码:Excel创建弹出菜单

    由于2007 MicrosoftOffice系统,Microsoft用功能区UI取代了命令栏菜单结构,这造成了创建在不同版本的MicrosoftOffice工作的菜单的技术会有所不同。...本文使用一种有效的技术创建在所有Excel版本中都可使用的弹出菜单。 注意,内置或自定义上下文菜单不同于弹出菜单的一种方式是,上下文菜单仅在右键单击鼠标时显示,而弹出菜单可以需要时显示。...VBE,单击“插入——模块”,标准模块的代码如下: Public Const Mname As String ="MyPopUpMenu" Sub DeletePopUpMenu() '...End Sub 回到Excel界面,按Alt+F8键,调出“宏”对话框,选择“CreateDisplayPopUpMenu”宏,单击“选项”按钮,“宏选项”对话框的“快捷键”输入字母m,如下图1所示...图1 这样,Excel工作表,按Ctrl+m组合键,会出现如下图2所示的弹出菜单。 图2 当单击菜单的按钮时,会弹出一个信息框,如下图3所示。

    3.4K51

    Excel创建一个瀑布图

    学习Excel技术,关注微信公众号: excelperfect 标签:Excel图表技巧,瀑布图 在前面的系列文章,我们介绍过几次Excel创建瀑布图的技巧。...本文再结合特定数据创建一个瀑布图。 示例数据如下图1所示。 图1 首先,我们将数据进行整理,将原始的一列数据转换成三列数据,如下图2所示。...图2 选择整理后的数据,单击功能区“插入”选项卡“图表”组的“插入柱形图或条形图——二维柱形图——堆积柱形图”,结果如下图3所示。 图3 选择图表的“不可见”系列,将其填充设置为“无填充”。...单击选取图表的任一系列,设置其间隙宽度为5%。 选择“黑色”系列,给其添加数据标签;同样,选择“白色”系列,给其添加数据标签。

    30820

    Excel小技巧41:Word创建Excel表的动态链接

    例如,我们可以Word中放置一个来自Excel的表,并且可以随着Excel该表的数据变化而动态更新。...这需要在Word创建一个对Excel表的动态链接,允许Word文档自动获取Excel表的变化并更新数据。 例如下图1所示的工作表,其中放置了一个Excel表,复制该表。 ?...图3 单击“确定”按钮后,该Excel的数据显示Word文档,如下图4所示。 ? 图4 此时,你返回到Excel工作表并修改其中的数据,如下图5所示。 ?...图5 Word文档的表数据将相应更新,如下图6所示。 ? 图6 Word文档和作为源数据的Excel文件同时打开时,Word文档会自动捕获到Excel的数据变化并更新。...图9 这样,每次要更新数据时,单击右键,快捷菜单中选择“更新链接”即可,如下图10所示。 ? 图10 实际上,当创建对单元格区域的链接后,Word将会存储源数据字段的信息,然后显示链接的数据。

    3.9K30

    不可思议的Excel图表12:Excel创建一座Masterchef风格的时钟

    这是chandoo.org上看到的一个有趣的图表制作示例,真的让人不由得感叹:只有想不到,没有做不到! 具体效果如下图1所示。...可以一张图表创建表盘和指针,也可分别创建,然后将它们重叠,这更简单一些。 制作表盘很简单。只需要一个范围60到5(60,55,50…10,5)的数字和十二个1。然后,选择它们并制作雷达图。...Excel相对应的是SIN(RADIANS(30)),COS(RADIANS(30))。 当时钟组装好后,工作还没有完成,必须通过VBA给它安装“电池”,使指针转动。...如果有兴趣,可以完美Excel公众号底部发消息: 动画时钟 下载示例工作簿研究。 undefined 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。

    1.1K20

    组件分享之后端组件——Golang快速读取和创建Excel

    组件分享之后端组件——Golang快速读取和创建Excel 背景 近期正在探索前端、后端、系统端各类常用组件与工具,对其一些常见的组件进行再次整理一下,形成标准化组件专题,后续该专题将包含各类语言中的一些常用组件...组件基本信息 组件:excelize 开源协议:BSD-3-Clause License 内容 本节我们分享的是基于Golang语言的Excel文件读写组件excelize Excelize是一个纯...具体使用方式如下: 1、安装基础包 go get github.com/xuri/excelize/v2 2、创建一个excel并存储内容 package main import ( "fmt...= nil { fmt.Println(err) } } 这样我们就完成了一个简单的excel文件创建和内容存储,是不是很简单,我们日常导出一些数据时这个方式是非常实用的一个方法...的内容了,日常进行导入数据时进行excel解析和处理很方便。

    1.3K20
    领券