软件国产化服务季来啦!整合所有格式的Aspose.Total永久授权正在火热促销中,乐享85折起!联系客服立马1分钟了解全部咨询!
Java API创建Excel文件
Aspose.Cells for Java是功能强大的电子表格处理API,可让您在没有MS Office的情况下创建或修改Excel文件。该API支持添加图表,图形,公式,并以编程方式执行其他电子表格操作操作。首先,您需要在Java环境中为Java API配置Aspose.Cells。您可以通过下载JAR文件或添加以下Maven存储库规范来进行设置:

使用Java创建Excel XLSX或XLS
MS Excel XLSX / XLS文件称为工作簿,每个工作簿均由一个或多个工作表组成。工作表还包含行和列,以将数据保持为单元格形式。因此,让我们从创建一个简单的工作簿开始。以下是从头开始创建Excel XLSX文件的步骤。
- 创建一个Workbook 类的实例
- 使用Workbook.getWorksheets.get() 方法访问所需的工作表
- 使用单元格的标识符(例如A1,B3等)将值放在工作表中的所需单元格中
- 使用Workbook.save() 方法将工作簿另存为Excel文件
下面的代码示例演示如何使用Java创建Excel XLSX文件。
// Create a new workbookWorkbook workbook = new Workbook();// Add value in the cellworkbook.getWorksheets().get(0).getCells().get("A1").putValue("Hello World!");// Save as Excel XLSX fileworkbook.save("Excel.xlsx");
让我们看一下此代码的屏幕截图:

现在让我们看一下如何修改数据或将数据插入到现有的MS Excel文件中。为此,您只需加载文件,访问所需的工作表并保存更新的文件即可。以下是修改现有Excel文件的步骤。
- 使用Workbook 类打开Excel文件 。
- 分别使用工作表和单元格类访问工作表和单元格
- 将更新后的工作簿保存为Excel .xlsx文件
// Create a new workbookWorkbook workbook = new Workbook("workbook.xls"); // Get the reference of "A1" cell from the cells of a worksheetCell cell = workbook.getWorksheets().get(0).getCells().get("A1");// Set the "Hello World!" value into the "A1" cellcell.setValue("updated cell value.");// Write the Excel fileworkbook.save("Excel.xls", FileFormatType.EXCEL_97_TO_2003);
使用Java在Excel XLSX中创建图表或图形
电子表格中的图表用于直观地表示工作表中存储的数据。它们使轻松轻松地分析大量数据变得容易。Aspose.Cells for Java提供了多种图表,您可以通过编程在Excel文件中创建这些图表。以下是在Excel XLSX文件中创建图表的步骤。
- 使用Workbook 类创建一个新的Excel文件或加载一个现有的文件 。
- 将数据添加到工作表(可选)。
- 使用Worksheet.getCharts() 方法获取工作表的图表集合。
- 使用Worksheet.getCharts().add() 方法添加新图表 。
- 从集合中获取新创建的图表。
- 指定单元格的范围以为图表设置NSeries。
- 将工作簿另存为Excel .xlsx 文件。
下面的代码示例演示如何使用Java在Excel XLSX中创建图表。
// Create a new workbookWorkbook workbook = new Workbook("workbook.xlsx"); // Obtaining the reference of the first worksheetWorksheetCollection worksheets = workbook.getWorksheets();Worksheet sheet = worksheets.get(0);// Adding some sample value to cellsCells cells = sheet.getCells();Cell cell = cells.get("A1");cell.setValue(50);cell = cells.get("A2");cell.setValue(100);cell = cells.get("A3");cell.setValue(150);cell = cells.get("B1");cell.setValue(4);cell = cells.get("B2");cell.setValue(20);cell = cells.get("B3");cell.setValue(50);// get charts in worksheetChartCollection charts = sheet.getCharts();// Adding a chart to the worksheetint chartIndex = charts.add(ChartType.PYRAMID, 5, 0, 15, 5);Chart chart = charts.get(chartIndex);// Adding NSeries (chart data source) to the chart ranging from "A1"// cell to "B3"SeriesCollection serieses = chart.getNSeries();serieses.add("A1:B3", true);// Write the Excel fileworkbook.save("Excel_with_Chart.xlsx");

使用Java在Excel XLSX中创建数据透视表
Excel工作表中的数据透视表具有多种用途,例如向数据添加过滤器,计算总计,汇总数据等。可以使用工作表中单元格的范围来创建数据透视表。以下是在Excel工作表中创建数据透视表的步骤。
- 创建一个新的工作簿或加载一个现有的文件。
- 在工作表中插入数据(可选)。
- 使用Worksheet.getPivotTables()方法访问透视表集合。
- 使用Worksheet.getPivotTables().add()方法在工作表中添加一个新的数据透视表。
- 为数据透视表提供数据。
- 保存工作簿。
下面的代码示例演示如何使用Java在Excel中创建数据透视表。
// Create a new workbookWorkbook workbook = new Workbook("workbook.xlsx"); // Get the first worksheet.Worksheet sheet = workbook.getWorksheets().get(0);// Obtaining Worksheet's cells collectionCells cells = sheet.getCells();// Setting the value to the cellsCell cell = cells.get("A1");cell.setValue("Sport");cell = cells.get("B1");cell.setValue("Quarter");cell = cells.get("C1");cell.setValue("Sales");cell = cells.get("A2");cell.setValue("Golf");cell = cells.get("A3");cell.setValue("Golf");cell = cells.get("A4");cell.setValue("Tennis");cell = cells.get("A5");cell.setValue("Tennis");cell = cells.get("A6");cell.setValue("Tennis");cell = cells.get("A7");cell.setValue("Tennis");cell = cells.get("A8");cell.setValue("Golf");cell = cells.get("B2");cell.setValue("Qtr3");cell = cells.get("B3");cell.setValue("Qtr4");cell = cells.get("B4");cell.setValue("Qtr3");cell = cells.get("B5");cell.setValue("Qtr4");cell = cells.get("B6");cell.setValue("Qtr3");cell = cells.get("B7");cell.setValue("Qtr4");cell = cells.get("B8");cell.setValue("Qtr3");cell = cells.get("C2");cell.setValue(1500);cell = cells.get("C3");cell.setValue(2000);cell = cells.get("C4");cell.setValue(600);cell = cells.get("C5");cell.setValue(1500);cell = cells.get("C6");cell.setValue(4070);cell = cells.get("C7");cell.setValue(5000);cell = cells.get("C8");cell.setValue(6430);PivotTableCollection pivotTables = sheet.getPivotTables();// Adding a PivotTable to the worksheetint index = pivotTables.add("=A1:C8", "E3", "PivotTable2");// Accessing the instance of the newly added PivotTablePivotTable pivotTable = pivotTables.get(index);// Unshowing grand totals for rows.pivotTable.setRowGrand(false);// Dragging the first field to the row area.pivotTable.addFieldToArea(PivotFieldType.ROW, 0);// Dragging the second field to the column area.pivotTable.addFieldToArea(PivotFieldType.COLUMN, 1);// Dragging the third field to the data area.pivotTable.addFieldToArea(PivotFieldType.DATA, 2);// Write the Excel fileworkbook.save("Excel_with_Chart.xlsx");

使用Java在Excel文件中添加单元格的公式
Aspose.Cells for Java还允许您使用Excel工作表中的公式。您可以将内置功能和附加功能应用于单元格。
在Excel中应用内置函数
对于使用内置函数,您可以简单地访问工作表中的所需单元格并使用Cell.setFormula(String)方法添加公式。下面的代码示例演示如何使用Java设置内置公式。
// Create a new workbookWorkbook workbook = new Workbook();// Add value in the cellworkbook.getWorksheets().get(0).getCells().get(0).setFormula("=H7*(1+IF(P7 =$L$3,$M$3, (IF(P7=$L$4,$M$4,0))))");// Save as Excel XLSX fileworkbook.save("Excel.xlsx");
在Excel中添加加载项功能
在某些情况下,您必须使用用户定义的函数。为此,您将必须使用.xlam(启用Excel宏的加载项)文件注册加载项功能,然后将其用于所需的单元格。为了注册附加功能,Aspose.Cells for Java提供了registerAddInFunction(int,String)和registerAddInFunction(String,String,boolean)方法。下面的代码示例演示如何使用Java注册和使用附加功能。
// create a new workbookWorkbook workbook = new Workbook();// Register macro enabled add-in along with the function nameint id = workbook.getWorksheets().registerAddInFunction("TESTUDF.xlam", "TEST_UDF", false);// Register more functions in the file (if any)workbook.getWorksheets().registerAddInFunction(id, "TEST_UDF1"); //in this way you can add more functions that are in the same file// Access first worksheetWorksheet worksheet = workbook.getWorksheets().get(0);// Access first cellCell cell = worksheet.getCells().get("A1");// Set formula name present in the add-incell.setFormula("=TEST_UDF()"); // Save as Excel XLSX fileworkbook.save("Excel.xlsx");
还想要更多吗可以点击阅读【2020 · Aspose最新资源整合】,查找需要的教程资源。如果您有任何疑问或需求,请随时加入Aspose技术交流群(),我们很高兴为您提供查询和咨询。
标签:
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!