| /******************************************************************************* | 
 |  * 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		21 Mar 2010 | 
 |  *******************************************************************************/ | 
 | using System; | 
 | using System.Collections.Generic; | 
 | using System.Text; | 
 | using System.IO; | 
 | using OfficeOpenXml; | 
 | using System.Xml; | 
 | using System.Drawing; | 
 | using OfficeOpenXml.Style; | 
 | namespace EPPlusSamples | 
 | { | 
 | 	class Sample1 | 
 | 	{ | 
 | 		/// <summary> | 
 | 		/// Sample 1 - simply creates a new workbook from scratch. | 
 | 		/// The workbook contains one worksheet with a simple invertory list | 
 | 		/// </summary> | 
 | 		public static string RunSample1(DirectoryInfo outputDir) | 
 | 		{ | 
 | 			FileInfo newFile = new FileInfo(outputDir.FullName + @"\sample1.xlsx"); | 
 | 			if (newFile.Exists) | 
 | 			{ | 
 | 				newFile.Delete();  // ensures we create a new workbook | 
 | 				newFile = new FileInfo(outputDir.FullName + @"\sample1.xlsx"); | 
 | 			} | 
 | 			using (ExcelPackage package = new ExcelPackage(newFile)) | 
 |             { | 
 |                 // add a new worksheet to the empty workbook | 
 |                 ExcelWorksheet worksheet = package.Workbook.Worksheets.Add("Inventory"); | 
 |                 //Add the headers | 
 |                 worksheet.Cells[1, 1].Value = "ID"; | 
 |                 worksheet.Cells[1, 2].Value = "Product"; | 
 |                 worksheet.Cells[1, 3].Value = "Quantity"; | 
 |                 worksheet.Cells[1, 4].Value = "Price"; | 
 |                 worksheet.Cells[1, 5].Value = "Value"; | 
 |  | 
 |                 //Add some items... | 
 |                 worksheet.Cells["A2"].Value = 12001; | 
 |                 worksheet.Cells["B2"].Value = "Nails"; | 
 |                 worksheet.Cells["C2"].Value = 37; | 
 |                 worksheet.Cells["D2"].Value = 3.99; | 
 |  | 
 |                 worksheet.Cells["A3"].Value = 12002; | 
 |                 worksheet.Cells["B3"].Value = "Hammer"; | 
 |                 worksheet.Cells["C3"].Value = 5; | 
 |                 worksheet.Cells["D3"].Value = 12.10; | 
 |  | 
 |                 worksheet.Cells["A4"].Value = 12003; | 
 |                 worksheet.Cells["B4"].Value = "Saw"; | 
 |                 worksheet.Cells["C4"].Value = 12; | 
 |                 worksheet.Cells["D4"].Value = 15.37; | 
 |  | 
 |                 //Add a formula for the value-column | 
 |                 worksheet.Cells["E2:E4"].Formula = "C2*D2"; | 
 |  | 
 |                 //Ok now format the values; | 
 |                 using (var range = worksheet.Cells[1, 1, 1, 5])  | 
 |                 { | 
 |                     range.Style.Font.Bold = true; | 
 |                     range.Style.Fill.PatternType = ExcelFillStyle.Solid; | 
 |                     range.Style.Fill.BackgroundColor.SetColor(Color.DarkBlue); | 
 |                     range.Style.Font.Color.SetColor(Color.White); | 
 |                 } | 
 |  | 
 |                 worksheet.Cells["A5:E5"].Style.Border.Top.Style = ExcelBorderStyle.Thin; | 
 |                 worksheet.Cells["A5:E5"].Style.Font.Bold = true; | 
 |  | 
 |                 worksheet.Cells[5, 3, 5, 5].Formula = string.Format("SUBTOTAL(9,{0})", new ExcelAddress(2,3,4,3).Address); | 
 |                 worksheet.Cells["C2:C5"].Style.Numberformat.Format = "#,##0"; | 
 |                 worksheet.Cells["D2:E5"].Style.Numberformat.Format = "#,##0.00"; | 
 |                  | 
 |                 //Create an autofilter for the range | 
 |                 worksheet.Cells["A1:E4"].AutoFilter = true; | 
 |  | 
 |                 worksheet.Cells["A2:A4"].Style.Numberformat.Format = "@";   //Format as text | 
 |  | 
 |                 //There is actually no need to calculate, Excel will do it for you, but in some cases it might be useful.  | 
 |                 //For example if you link to this workbook from another workbook or you will open the workbook in a program that hasn't a calculation engine or  | 
 |                 //you want to use the result of a formula in your program. | 
 |                 worksheet.Calculate();  | 
 |  | 
 |                 worksheet.Cells.AutoFitColumns(0);  //Autofit columns for all cells | 
 |  | 
 |                 // lets set the header text  | 
 |                 worksheet.HeaderFooter.OddHeader.CenteredText = "&24&U&\"Arial,Regular Bold\" Inventory"; | 
 |                 // add the page number to the footer plus the total number of pages | 
 |                 worksheet.HeaderFooter.OddFooter.RightAlignedText = | 
 |                     string.Format("Page {0} of {1}", ExcelHeaderFooter.PageNumber, ExcelHeaderFooter.NumberOfPages); | 
 |                 // add the sheet name to the footer | 
 |                 worksheet.HeaderFooter.OddFooter.CenteredText = ExcelHeaderFooter.SheetName; | 
 |                 // add the file path to the footer | 
 |                 worksheet.HeaderFooter.OddFooter.LeftAlignedText = ExcelHeaderFooter.FilePath + ExcelHeaderFooter.FileName; | 
 |  | 
 |                 worksheet.PrinterSettings.RepeatRows = worksheet.Cells["1:2"]; | 
 |                 worksheet.PrinterSettings.RepeatColumns = worksheet.Cells["A:G"]; | 
 |  | 
 |                 // Change the sheet view to show it in page layout mode | 
 |                 worksheet.View.PageLayoutView = true; | 
 |  | 
 |                 // set some document properties | 
 |                 package.Workbook.Properties.Title = "Invertory"; | 
 |                 package.Workbook.Properties.Author = "Jan Källman"; | 
 |                 package.Workbook.Properties.Comments = "This sample demonstrates how to create an Excel 2007 workbook using EPPlus"; | 
 |  | 
 |                 // set some extended property values | 
 |                 package.Workbook.Properties.Company = "AdventureWorks Inc."; | 
 |  | 
 |                 // set some custom property values | 
 |                 package.Workbook.Properties.SetCustomPropertyValue("Checked by", "Jan Källman"); | 
 |                 package.Workbook.Properties.SetCustomPropertyValue("AssemblyName", "EPPlus"); | 
 |                 // save our new workbook and we are done! | 
 |                 package.Save(); | 
 |  | 
 |             } | 
 |  | 
 |             return newFile.FullName; | 
 | 		} | 
 | 	} | 
 | } |