如果数据太大,自动将智能标记数据填充到其他工作表

可能的使用场景

有时,如果智能标记数据太大,您希望将其自动填充到其他工作表。假设,您的数据源有 1500000 条记录。这些记录对于单个工作表来说太多了,那么您可以将其余记录移动到下一个工作表。

如果数据太大,自动将智能标记数据填充到其他工作表

以下示例代码有一个包含 21 条记录的数据源。我们希望在一个工作表中只显示 15 条记录,然后其余记录将自动移动到第二个工作表。请注意,第二个工作表也应具有相同的智能标记标签,您必须调用WorkbookDesigner.process(sheetIndex, isPreserved) 两张纸的方法。请检查Microsoft 访问数据库文件在此代码中使用以及输出Excel文件生成的代码供参考。

示例代码

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
// Create Connection object - connect to Microsoft Access Students Database
java.sql.Connection conn = java.sql.DriverManager.getConnection("jdbc:ucanaccess://" + srcDir + "sampleAutoPopulateSmartMarkerDataToOtherWorksheets.accdb");
// Create SQL Statement with Connection object
java.sql.Statement st = conn.createStatement();
// Execute SQL Query and obtain ResultSet
java.sql.ResultSet rsEmployees = st.executeQuery("SELECT * FROM Employees");
//Create empty workbook
Workbook wb = new Workbook();
//Access first worksheet and add smart marker in cell A1
Worksheet ws = wb.getWorksheets().get(0);
ws.getCells().get("A1").putValue("&=Employees.EmployeeID");
//Add second worksheet and add smart marker in cell A1
wb.getWorksheets().add();
ws = wb.getWorksheets().get(1);
ws.getCells().get("A1").putValue("&=Employees.EmployeeID");
//Create workbook designer
WorkbookDesigner wd = new WorkbookDesigner(wb);
//Set data source with result set
wd.setDataSource("Employees", rsEmployees, 15);
//Process smart marker tags in first and second worksheet
wd.process(0, false);
wd.process(1, false);
//Save the workbook
wb.save("outputAutoPopulateSmartMarkerDataToOtherWorksheets.xlsx");