| /******************************************************************************* |
| * You may amend and distribute as you like, but don't remove this header! |
| * |
| * All rights reserved. |
| * |
| * EPPlus is an Open Source project provided under the |
| * GNU General Public License (GPL) as published by the |
| * Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| * |
| * EPPlus provides server-side generation of Excel 2007 spreadsheets. |
| * See http://www.codeplex.com/EPPlus for details. |
| * |
| * |
| * |
| * The GNU General Public License can be viewed at http://www.opensource.org/licenses/gpl-license.php |
| * If you unfamiliar with this license or have questions about it, here is an http://www.gnu.org/licenses/gpl-faq.html |
| * |
| * The code for this project may be used and redistributed by any means PROVIDING it is |
| * not sold for profit without the author's written consent, and providing that this notice |
| * and the author's name and all copyright notices remain intact. |
| * |
| * All code and executables are provided "as is" with no warranty either express or implied. |
| * The author accepts no liability for any damage or loss of business that this product may cause. |
| * |
| * |
| * Code change notes: |
| * |
| * Author Change Date |
| ******************************************************************************* |
| * Jan Källman Added 28 Oct 2010 |
| *******************************************************************************/ |
| using System; |
| using System.Collections.Generic; |
| using System.Linq; |
| using System.Text; |
| using OfficeOpenXml; |
| using System.IO; |
| using OfficeOpenXml.Table; |
| using OfficeOpenXml.Drawing.Chart; |
| using System.Globalization; |
| namespace EPPlusSamples |
| { |
| /// <summary> |
| /// This sample shows how to load CSV files using the LoadFromText method, how to use tables and |
| /// how to use charts with more than one charttype and secondary axis |
| /// </summary> |
| public static class Sample9 |
| { |
| /// <summary> |
| /// Loads two CSV files into tables and adds a chart to each sheet. |
| /// </summary> |
| /// <param name="outputDir"></param> |
| /// <returns></returns> |
| public static string RunSample9(DirectoryInfo outputDir) |
| { |
| FileInfo newFile = new FileInfo(outputDir.FullName + @"\sample9.xlsx"); |
| if (newFile.Exists) |
| { |
| newFile.Delete(); // ensures we create a new workbook |
| newFile = new FileInfo(outputDir.FullName + @"\sample9.xlsx"); |
| } |
| |
| using (ExcelPackage package = new ExcelPackage()) |
| { |
| LoadFile1(package); |
| LoadFile2(package); |
| |
| package.SaveAs(newFile); |
| } |
| return newFile.FullName; |
| } |
| private static void LoadFile1(ExcelPackage package) |
| { |
| //Create the Worksheet |
| var sheet = package.Workbook.Worksheets.Add("Csv1"); |
| |
| //Create the format object to describe the text file |
| var format = new ExcelTextFormat(); |
| format.TextQualifier = '"'; |
| format.SkipLinesBeginning = 2; |
| format.SkipLinesEnd = 1; |
| |
| //Now read the file into the sheet. Start from cell A1. Create a table with style 27. First row contains the header. |
| Console.WriteLine("Load the text file..."); |
| var range = sheet.Cells["A1"].LoadFromText(new FileInfo("..\\..\\csv\\Sample9-1.txt"), format, TableStyles.Medium27, true); |
| |
| Console.WriteLine("Format the table..."); |
| //Tables don't support custom styling at this stage(you can of course format the cells), but we can create a Namedstyle for a column... |
| var dateStyle = package.Workbook.Styles.CreateNamedStyle("TableDate"); |
| dateStyle.Style.Numberformat.Format = "YYYY-MM"; |
| |
| var numStyle = package.Workbook.Styles.CreateNamedStyle("TableNumber"); |
| numStyle.Style.Numberformat.Format = "#,##0.0"; |
| |
| //Now format the table... |
| var tbl = sheet.Tables[0]; |
| tbl.ShowTotal = true; |
| tbl.Columns[0].TotalsRowLabel = "Total"; |
| tbl.Columns[0].DataCellStyleName = "TableDate"; |
| tbl.Columns[1].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[1].DataCellStyleName = "TableNumber"; |
| tbl.Columns[2].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[2].DataCellStyleName = "TableNumber"; |
| tbl.Columns[3].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[3].DataCellStyleName = "TableNumber"; |
| tbl.Columns[4].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[4].DataCellStyleName = "TableNumber"; |
| tbl.Columns[5].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[5].DataCellStyleName = "TableNumber"; |
| tbl.Columns[6].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[6].DataCellStyleName = "TableNumber"; |
| |
| Console.WriteLine("Create the chart..."); |
| //Now add a stacked areachart... |
| var chart = sheet.Drawings.AddChart("chart1", eChartType.AreaStacked); |
| chart.SetPosition(0, 630); |
| chart.SetSize(800, 600); |
| |
| //Create one series for each column... |
| for (int col = 1; col < 7; col++) |
| { |
| var ser = chart.Series.Add(range.Offset(1, col, range.End.Row - 1, 1), range.Offset(1, 0, range.End.Row - 1, 1)); |
| ser.HeaderAddress = range.Offset(0, col, 1, 1); |
| } |
| |
| //Set the style to 27. |
| chart.Style = eChartStyle.Style27; |
| |
| sheet.View.ShowGridLines = false; |
| sheet.Calculate(); |
| sheet.Cells[sheet.Dimension.Address].AutoFitColumns(); |
| } |
| |
| private static void LoadFile2(ExcelPackage package) |
| { |
| //Create the Worksheet |
| var sheet = package.Workbook.Worksheets.Add("Csv2"); |
| |
| //Create the format object to describe the text file |
| var format = new ExcelTextFormat(); |
| format.Delimiter='\t'; //Tab |
| format.SkipLinesBeginning = 1; |
| CultureInfo ci = new CultureInfo("sv-SE"); //Use your choice of Culture |
| ci.NumberFormat.NumberDecimalSeparator = ","; //Decimal is comma |
| format.Culture = ci; |
| |
| //Now read the file into the sheet. |
| Console.WriteLine("Load the text file..."); |
| var range = sheet.Cells["A1"].LoadFromText(new FileInfo("..\\..\\csv\\Sample9-2.txt"), format); |
| |
| //Add a formula |
| range.Offset(1, range.End.Column, range.End.Row - range.Start.Row, 1).FormulaR1C1 = "RC[-1]-RC[-2]"; |
| |
| //Add a table... |
| var tbl = sheet.Tables.Add(range.Offset(0,0,range.End.Row-range.Start.Row+1, range.End.Column-range.Start.Column+2),"Table"); |
| tbl.ShowTotal = true; |
| tbl.Columns[0].TotalsRowLabel = "Total"; |
| tbl.Columns[1].TotalsRowFormula = "COUNT(3,Table[Product])"; //Add a custom formula |
| tbl.Columns[2].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[3].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[4].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[5].TotalsRowFunction = RowFunctions.Sum; |
| tbl.Columns[5].Name = "Profit"; |
| tbl.TableStyle = TableStyles.Medium10; |
| |
| sheet.Cells[sheet.Dimension.Address].AutoFitColumns(); |
| |
| //Add a chart with two charttypes (Column and Line) and a secondary axis... |
| var chart = sheet.Drawings.AddChart("chart2", eChartType.ColumnStacked); |
| chart.SetPosition(0, 540); |
| chart.SetSize(800, 600); |
| |
| var serie1= chart.Series.Add(range.Offset(1, 3, range.End.Row - 1, 1), range.Offset(1, 1, range.End.Row - 1, 1)); |
| serie1.Header = "Purchase Price"; |
| var serie2 = chart.Series.Add(range.Offset(1, 5, range.End.Row - 1, 1), range.Offset(1, 1, range.End.Row - 1, 1)); |
| serie2.Header = "Profit"; |
| |
| //Add a Line series |
| var chartType2 = chart.PlotArea.ChartTypes.Add(eChartType.LineStacked); |
| chartType2.UseSecondaryAxis = true; |
| var serie3 = chartType2.Series.Add(range.Offset(1, 2, range.End.Row - 1, 1), range.Offset(1, 0, range.End.Row - 1, 1)); |
| serie3.Header = "Items in stock"; |
| |
| //By default the secondary XAxis is not visible, but we want to show it... |
| chartType2.XAxis.Deleted = false; |
| chartType2.XAxis.TickLabelPosition = eTickLabelPosition.High; |
| |
| //Set the max value for the Y axis... |
| chartType2.YAxis.MaxValue = 50; |
| |
| chart.Style = eChartStyle.Style26; |
| sheet.View.ShowGridLines = false; |
| sheet.Calculate(); |
| } |
| } |
| } |