Skip to main content

How to Generate Excel from JSON Data Using Asp.net(C#).

Here I will explain how to generate excel from json.
I am using NPOI and Newtonsoft.Json third party dll for this.

Download dll from here :  https://drive.google.com/file/d/0B2UW8NPznIKsdzJSWDBDX2xLSms/view

JSON For Test : [   {     "ID" : "1",     "NAME" : "Nikhil Sangani",     "MOBILENO" : "123456789",     "DESIGNATION" : "Web Developer"  } ]


First of all i am create aspx page design like this.


<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <table>
            <tr>
                <td>
                    JSON STRING :<asp:TextBox runat="server" ID="txtjsonstring"></asp:TextBox>
                </td>
            </tr>
            <tr>
                <td>
                    <asp:Button runat="server" ID="BtnExcel" Text="Excel" OnClick="BtnExcel_Click" />
                </td>
            </tr>
        </table>
    </div>
    </form>
</body>
</html>


After that put this code on your code behind file.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using NPOI.SS.UserModel;
using System.Data;
using NPOI.HSSF.UserModel;
using NPOI.HSSF.Util;
using System.IO;
using Newtonsoft.Json;


namespace testProject
{
    public partial class WebForm1 : System.Web.UI.Page
    {    
        protected void Page_Load(object sender, EventArgs e)
        {       

        }

        public Workbook ExportToExcel(DataTable ExcelTable, string FileName)
        {
            DataTable dtTemp = new DataTable();

            for (int i = 0; i < ExcelTable.Columns.Count; i++)
            {
                dtTemp.Columns.Add(ExcelTable.Columns[i].ColumnName);
            }

            // Create a new workbook and a sheet name

            HSSFWorkbook workbook = new HSSFWorkbook();
            CreationHelper createHelper = workbook.GetCreationHelper();
            Sheet sheet = workbook.CreateSheet("Nikhil Sangani");          

            // Add header labels
            int rowIndex = 0;
            Row row = sheet.CreateRow(rowIndex);
            NPOI.SS.UserModel.Font Headerfont = workbook.CreateFont();
            Headerfont.FontName = "Arial";
            Headerfont.FontHeightInPoints = 10;
            Headerfont.Boldweight = (short)NPOI.SS.UserModel.FontBoldWeight.BOLD;
          

            foreach (DataColumn column in dtTemp.Columns)
            {
                Cell headerCell = row.CreateCell(column.Ordinal);
                headerCell.SetCellValue(column.ColumnName);
                CellStyle headerCellStyle = workbook.CreateCellStyle();
                headerCellStyle.FillForegroundColor = HSSFColor.SKY_BLUE.index;
                headerCellStyle.FillPattern = FillPatternType.SOLID_FOREGROUND;
                headerCellStyle.Alignment = HorizontalAlignment.CENTER;
                headerCellStyle.SetFont(Headerfont);
                headerCellStyle.BorderBottom = CellBorderType.THIN;
                headerCellStyle.BottomBorderColor = HSSFColor.BLACK.index;
                headerCellStyle.BorderLeft = CellBorderType.THIN;
                headerCellStyle.LeftBorderColor = HSSFColor.BLACK.index;
                headerCellStyle.BorderRight = CellBorderType.THIN;
                headerCellStyle.RightBorderColor = HSSFColor.BLACK.index;
                headerCellStyle.BorderTop = CellBorderType.THIN;
                headerCellStyle.TopBorderColor = HSSFColor.BLACK.index;
                headerCell.CellStyle = headerCellStyle;
            }
            rowIndex++;


            NPOI.SS.UserModel.Font font = workbook.CreateFont();
            font.FontName = "Calibri";
            font.FontHeightInPoints = 9;

            CellStyle FontCellStyle = workbook.CreateCellStyle();
            FontCellStyle.SetFont(font);
            FontCellStyle.BorderBottom = CellBorderType.THIN;
            FontCellStyle.BottomBorderColor = HSSFColor.BLACK.index;
            FontCellStyle.BorderLeft = CellBorderType.THIN;
            FontCellStyle.LeftBorderColor = HSSFColor.BLACK.index;
            FontCellStyle.BorderRight = CellBorderType.THIN;
            FontCellStyle.RightBorderColor = HSSFColor.BLACK.index;
            FontCellStyle.BorderTop = CellBorderType.THIN;
            FontCellStyle.TopBorderColor = HSSFColor.BLACK.index;
          

            foreach (DataRow roww in ExcelTable.Rows)
            {
                row = (HSSFRow)sheet.CreateRow(rowIndex);
                foreach (DataColumn column in ExcelTable.Columns)
                {
                    row.CreateCell(column.Ordinal).SetCellValue(roww[column].ToString());
                }
                rowIndex++;
            }


            // Auto-size each column
            for (int i = 0; i < sheet.GetRow(0).LastCellNum; i++)
            {
                sheet.AutoSizeColumn(i);
            }

            for (int i = 1; i < sheet.LastRowNum - 5; i++)
            {
                for (int j = 0; j < sheet.GetRow(i).LastCellNum; j++)
                {
                    if (j != 0 && j != 1 && j != 2 && j != 3 && j != 4 && j != 5)
                    {
                        sheet.GetRow(i).GetCell(j).CellStyle = FontCellStyle;
                    }
                }
            }
            return workbook;
        }

        protected void BtnExcel_Click(object sender, EventArgs e)
        {

            Workbook workbook = new HSSFWorkbook();
            string FileName = "Nikhil" + "_" + DateTime.Today.ToString("dd_MM_yy").ToString() + "_" + DateTime.Now.ToString("hh_mm_ss").ToString() + ".xls";

     //Here convert JSON to DataTable.

            DataTable dtValue1 = (DataTable)JsonConvert.DeserializeObject(txtjsonstring.Text, (typeof(DataTable)));
            workbook = ExportToExcel(dtValue1, FileName);
            using (var exportData = new MemoryStream())
            {
                workbook.Write(exportData);
                string saveAsFileName = FileName;
                Response.ContentType = "application/vnd.ms-excel";
                Response.AddHeader("Content-Disposition", string.Format("attachment;filename={0}", saveAsFileName));
                Response.Clear();
                Response.BinaryWrite(exportData.GetBuffer());
                Response.End();
            }
        }
    }
}


InPut: 



Output :



Comments

Popular posts from this blog

How To Implement NLog With WebAPI In Asp.Net(C#).

What is NLog? NLog is a flexible and free logging platform for various .NET platforms, including .NET standard. NLog is easy to apply and it includes several targets (database, file, event viewer). Which platform support it? .NET Framework 3.5, 4, 4.5, 4.6 & 4.7 .NET Framework 4 client profile Xamarin Android Xamarin iOS Windows Phone 8 Silver light 4 and 5 Mono 4 ASP.NET 4 (NLog.Web package) ASP.NET Core (NLog.Web.AspNetCore package) .NET Core (NLog.Extensions.Logging package) .NET Standard 1.x - NLog 4.5 .NET Standard 2.x - NLog 4.5 UWP - NLog 4.5 There are several log levels. Fatal : Something terrible occurred; the application is going down  Error : Something fizzled; the application might possibly proceed Warn : Something surprising; the application will proceed  Info : Normal conduct like mail sent, client refreshed profile and so on.  Debug : For troubleshooting; the executed question, the client confirmed, ...

Generating serial numbers and keys in Asp.net(C#).

here we are using GUID for generate serial numbers and GUID is always unique. Example format: XXXX-XXXX-XXXX-XXXX-XXXX-XXXX-XXXX. Guid SerialKeyGuid = Guid.NewGuid(); string AccessKey = SerialKeyGuid.ToString("N"); string AccessKeyLength = AccessKey.Substring(0, 28).ToUpper(); char[] serialArray = AccessKeyLength.ToCharArray(); string SerialNumber = ""; int P = 0; for (int B = 0; B < 28; B++) {                 for (P = B; P < 4 + B; P++)                 {                     SerialNumber += serialArray[P];                 }                 if (P == 28)                 {                     break;                 }         ...

Extracting Values from PDFs in .NET Core 8 without ASP.NET

Extracting data from PDF files is a common necessity for various tasks such as data analysis, content indexing, and information retrieval. While ASP.NET Core 8 offers robust tools for PDF manipulation, there are instances where developers may prefer alternatives for flexibility or specific project requirements. In this article, we'll explore how to extract values from PDF files within the .NET Core 8 ecosystem without relying on ASP.NET, using the PdfSharpCore library. We'll provide a step-by-step guide along with examples in C# to demonstrate how to accomplish this task effectively. Understanding PdfSharpCore: PdfSharpCore is a popular .NET library for PDF document manipulation. It provides functionalities to create, modify, and extract content from PDF files. In this guide, we'll focus on utilizing PdfSharpCore to extract text from PDF documents. Installing PdfSharpCore: Before we can start using PdfSharpCore in our .NET Core application, we need to install the PdfSharpCo...