When loading a file, GemBox.Spreadsheet by default loads everything into a content model. When the loaded file is huge, the whole model can occupy a lot of memory, or it might not even fit.To overcome this problem, you can use streamlined loading, which doesn't load the whole spreadsheet into the model but loads a set of rows only when they are requested. After the new set of rows is requested, the old one is cleared from the memory. This approach significantly decreases memory consumption, even when iterating through the whole file.The following example shows how you can load the file in streamlined mode and obtain the values using the same API as you would normally.C#VB.NET Copy View on GitHub using GemBox.Spreadsheet;class Program static void Main() // If using the Professional version, put your serial key below. SpreadsheetInfo.SetLicense("FREE-LIMITED-KEY"); // Load the workbook using the streaming mode. var workbook = ExcelFile.Load("huge.xlsx", new XlsxLoadOptions() StreamingMode = LoadStreamingMode.Read ); // Get values from the workbook as you normally would. var worksheet = workbook.Worksheets[0]; foreach (var row in worksheet.Rows) foreach (var cell in row.AllocatedCells) var value = cell.Value; // Process the value... Imports GemBox.SpreadsheetModule Program Sub Main() ' If using the Professional version, put your serial key below. SpreadsheetInfo.SetLicense("FREE-LIMITED-KEY") ' Load the workbook using the streaming mode. Dim workbook = ExcelFile.Load("huge.xlsx", New XlsxLoadOptions() With .StreamingMode = LoadStreamingMode.Read ) ' Get values from the workbook as you normally would. Dim worksheet = workbook.Worksheets(0) For Each row In worksheet.Rows For Each cell In row.AllocatedCells Dim value = cell.Value ' Process the value... Next Next End SubEnd ModuleThe following chart shows the timeline of memory consumption when loading a very large (1 million rows, each having 50 cells, total size 50MB) and comparing the file in the default and the streaming mode.
gembox spreadsheet professional serial 48
2ff7e9595c
Comentários