-
Notifications
You must be signed in to change notification settings - Fork 13
Expand file tree
/
Copy pathUsingAsyncAwaitSample.cs
More file actions
70 lines (62 loc) · 2.95 KB
/
UsingAsyncAwaitSample.cs
File metadata and controls
70 lines (62 loc) · 2.95 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/*************************************************************************************************
Required Notice: Copyright (C) EPPlus Software AB.
This software is licensed under PolyForm Noncommercial License 1.0.0
and may only be used for noncommercial purposes
https://polyformproject.org/licenses/noncommercial/1.0.0/
A commercial license to use this software can be purchased at https://epplussoftware.com
*************************************************************************************************
Date Author Change
*************************************************************************************************
01/27/2020 EPPlus Software AB Initial release EPPlus 5
*************************************************************************************************/
using System;
using OfficeOpenXml;
using System.Data.SqlClient;
using System.Drawing;
using OfficeOpenXml.Style;
using System.Data.SQLite;
using System.Threading.Tasks;
using System.Threading;
using OfficeOpenXml.Table;
using System.Text;
using EPPlusSamples.FiltersAndValidations;
namespace EPPlusSamples.WorkbookWorksheetAndRanges
{
class UsingAsyncAwaitSample
{
/// <summary>
/// Shows a few different ways to load / save asynchronous
/// </summary>
public static async Task RunAsync()
{
Console.WriteLine("Running sample 1.3-Async-Await");
var file = FileUtil.GetCleanFileInfo("1.03-AsyncAwait.xlsx");
using (ExcelPackage package = new ExcelPackage(file))
{
var ws = package.Workbook.Worksheets.Add("Sheet1");
using (var sqlConn = new SQLiteConnection(SampleSettings.ConnectionString))
{
sqlConn.Open();
var sql = SqlStatements.OrdersSql;
using (var sqlCmd = new SQLiteCommand(sql, sqlConn))
{
var range = await ws.Cells["B2"].LoadFromDataReaderAsync(sqlCmd.ExecuteReader(), true, "Table1", TableStyles.Medium10);
range.AutoFitColumns();
}
}
await package.SaveAsync();
}
//Load the package async again.
using (var package = new ExcelPackage())
{
await package.LoadAsync(file);
var newWs = package.Workbook.Worksheets.Add("AddedSheet2");
var range = await newWs.Cells["A1"].LoadFromTextAsync(FileUtil.GetFileInfo("01-Workbook Worksheet and Ranges\\03-Using Async Await", "Importfile.txt"), new ExcelTextFormat { Delimiter='\t' });
range.AutoFitColumns();
await package.SaveAsAsync(FileUtil.GetCleanFileInfo("1.03-AsyncAwait-LoadedAndModified.xlsx"));
}
Console.WriteLine("Sample 1.3 created {0}", FileUtil.OutputDir.Name);
Console.WriteLine();
}
}
}