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 See Logs Of Dropped Tables From The Database in MS SQL.

Here, I will explain you how you can see logs of users. Step 1 : First, create a new database with name "test". Step 2 : Create a new table. Step 3 : Now, go and drop the table by running the following command. Step 4 : Now, select your database under Object Explorer and go to Reports >> Standard Reports >> Schema Changes History. Step 5 : You will then see the schema change history. The report will show you who has dropped this table. Finally, you can locate the user activity with the help of log.

How To Deploy .net Core Application On Linux

Here, I can explain steps to deploy .net core application on linux machine. Step 1 - Publish your .net Core application: First, create a .net core application on VS; you can make an MVC project or Web API project and if you already have an existing project, then open it. Right Click on your project Click on publish Now create a new publish profile, and browse the folder where you want to publish your project dll Click on publish so it will create your dll in the folder Step 2 - Install required .net Module on Linux: Now we have our web application dll and now we need to host it on the Linux environment. First, we need to understand how the deployment works in Linux. .Net applications run on Kestrel servers and we run Apache or Nginx server in Linux environments, which acts as a proxy server and handles the traffic from outside the machine and redirects it to the Kestrel server so we will have Apache or Nginx server as the middle layer. In this article, we will use Apache as a proxy ser

List Of Commonly Used Angular Commands

1) To get the npm version,    npm -v 2) To get the node version,    node -v 3) To get the Angular version,    ng v  4) To get the Jasmine version,    jasmine -v  5) To get the Karma version,    karma --version  6) To install Angular CLI,    npm install @angular/cli -g   npm install @angular/cli 7) To install the next version of Angular CLI, v   npm install @angular/cli@next  8) To get help in the terminal,    ng help 9) To create a new project in Angular,    ng new project-name  10) To skip external dependencies while creating a new project,    ng new project-name --skip-install  11) To run the Angular project,   ng serve (or) npm start (or) ng serve --force  12) Dry Run,   ng new project-name --dry-run 13) To create a new component in the Angular Project,   ng generate component component-