EasyXLS

How to create chart in a worksheet in C#.NET

EasyXLS Excel library can be used to export Excel files in C#. The library works with .NET Framework or .NET Core platform.

Step 1: Download EasyXLS Excel Library for .NET

To download the trial version of EasyXLS Excel Library, press the below button:

Download EasyXLS™ Excel Library for C#

If you already own a license key, you may login and download EasyXLS from your account.

Install the downloaded EasyXLS installer for v8.6 or earlier.

Step 2: License file setup

Step required for EasyXLS v9.0 or later.

If you are using a trial, generate a trial license file from EasyXLS trials page. The trial license is valid for 30-days.

If you own a license key, you may login to the account that purchased the license and generate the license file from:
https://www.easyxls.com/my-orders

Setup the license file into your project using these guidelines.

Step 3: Create a C# project

If don't have a project, create one as ASP.NET web application, windows forms app, console application, class library or service.

Step 4: Include EasyXLS library into project

EasyXLS.dll must be added as reference to your project. EasyXLS.dll can be found:
- Inside the downloaded archive at Step 1 for EasyXLS v9.0 or later
- Under installation path for EasyXLS v8.6 or earlier, in "Dot NET version" folder.

Add EasyXLS reference

Step 5: Run C# code that creates a chart in a worksheet

Execute the following C# code that exports a chart to Excel and the chart is placed inside a worksheet.

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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/* ----------------------------------------------------------
 * Tutorial 24
 * 
 * This tutorial shows how to create an Excel file in C# and
 * to create a chart in a worksheet.
 * ---------------------------------------------------------- */

using System;
using EasyXLS;
using EasyXLS.Charts;
using EasyXLS.Constants;

public class Tutorial24
{
    [STAThread]
    static void Main()
    {
        Console.WriteLine("Tutorial 24\n----------\n");

        // Create an instance of the class that exports Excel files
        ExcelDocument workbook = new ExcelDocument();
    
        // Create an worksheet
        workbook.easy_addWorksheet("SourceData");

        // Get the table of data for the worksheet
        ExcelTable xlsTable1 = ((ExcelWorksheet)workbook.easy_getSheet("SourceData")).easy_getExcelTable();

        // Add data in cells for report header
        xlsTable1.easy_getCell(0, 0).setValue("Show Date");
        xlsTable1.easy_getCell(0, 1).setValue("Available Places");
        xlsTable1.easy_getCell(0, 2).setValue("Available Tickets");
        xlsTable1.easy_getCell(0, 3).setValue("Sold Tickets");

        // Add data in cells for chart report values
        xlsTable1.easy_getCell(1, 0).setValue("03/13/2005 00:00:00");
        xlsTable1.easy_getCell(1, 0).setFormat(EasyXLS.Constants.Format.FORMAT_DATE);
        xlsTable1.easy_getCell(2, 0).setValue("03/14/2005 00:00:00");
        xlsTable1.easy_getCell(2, 0).setFormat(EasyXLS.Constants.Format.FORMAT_DATE);
        xlsTable1.easy_getCell(3, 0).setValue("03/15/2005 00:00:00");
        xlsTable1.easy_getCell(3, 0).setFormat(EasyXLS.Constants.Format.FORMAT_DATE);
        xlsTable1.easy_getCell(4, 0).setValue("03/16/2005 00:00:00");
        xlsTable1.easy_getCell(4, 0).setFormat(EasyXLS.Constants.Format.FORMAT_DATE);

        xlsTable1.easy_getCell(1, 1).setValue("10000");
        xlsTable1.easy_getCell(2, 1).setValue("5000");
        xlsTable1.easy_getCell(3, 1).setValue("8500");
        xlsTable1.easy_getCell(4, 1).setValue("1000");

        xlsTable1.easy_getCell(1, 2).setValue("8000");
        xlsTable1.easy_getCell(2, 2).setValue("4000");
        xlsTable1.easy_getCell(3, 2).setValue("6000");
        xlsTable1.easy_getCell(4, 2).setValue("1000");

        xlsTable1.easy_getCell(1, 3).setValue("920");
        xlsTable1.easy_getCell(2, 3).setValue("1005");
        xlsTable1.easy_getCell(3, 3).setValue("342");
        xlsTable1.easy_getCell(4, 3).setValue("967");

        // Set column widths
        xlsTable1.easy_getColumnAt(0).setWidth(100);
        xlsTable1.easy_getColumnAt(1).setWidth(100);
        xlsTable1.easy_getColumnAt(2).setWidth(100);
        xlsTable1.easy_getColumnAt(3).setWidth(100);
        
        // Create a chart
        ExcelChart xlsChart = new ExcelChart("A10", 600, 300);
        xlsChart.easy_addSeries("=SourceData!$B$1", "=SourceData!$B$2:$B$5");
        xlsChart.easy_addSeries("=SourceData!$C$1", "=SourceData!$C$2:$C$5");
        xlsChart.easy_addSeries("=SourceData!$D$1", "=SourceData!$D$2:$D$5");
        xlsChart.easy_setCategoryXAxisLabels("=SourceData!$A$2:$A$5");

        // Add the chart to the first worksheet
        ((ExcelWorksheet)workbook.easy_getSheet("SourceData")).easy_addChart(xlsChart);

        // Export Excel file
        Console.WriteLine("Writing file C:\\Samples\\Tutorial24 - chart inside worksheet.xlsx.");
        workbook.easy_WriteXLSXFile("C:\\Samples\\Tutorial24 - chart inside worksheet.xlsx");

        // Confirm export of Excel file
        String sError = workbook.easy_getError();
        if (sError.Equals(""))
            Console.Write("\nFile successfully created. Press Enter to Exit...");
        else
            Console.Write("\nError encountered: " + sError + "\nPress Enter to Exit...");

        // Dispose memory
        workbook.Dispose();

        Console.ReadLine();
    }
}

EasyXLS Excel libraries:

.NET
Excel Library for C#
full .NET version to import, export or convert Excel files
Excel Writer for C#
.NET version to create and export Excel files
Download EasyXLS™ Excel Library for C#

File formats:

Office 365
MS Excel 2021 - 2024
MS Excel 2007 - 2019
MS Excel 97 - 2003
XLSXXLSMXLSBXLS
XMLHTMLCSVTXT