2016-07-27 30 views
-2

GridViewをExcelファイルにエクスポートしていますが、ファイルを開いたときに最初にフォーマットのタイプと拡張子が一致しないというエラーが表示され、開いたときにページ全体がExcelファイル、グリッドビューだけではありません。GridViewをExcelにエクスポートするにはどうすればよいですか?

enter code here 

    protected void ExportToExcel(object sender, EventArgs e) 
     { 
      try 
      { 
       Response.Clear(); 
       Response.Buffer = true; 
       Response.AddHeader("content-disposition", "attachment;filename=GridViewExport.xls"); 
       Response.Charset = ""; 
       Response.ContentType = "application/vnd.ms-excel"; 
       using (StringWriter sw = new StringWriter()) 
       { 
        HtmlTextWriter hw = new HtmlTextWriter(sw); 

        //To Export all pages 
        gridCustomer.AllowPaging = false; 
        //this.gridCustInfoBind(1); 
        gridCustAllInfoBind(1); 

        gridCustomer.HeaderRow.BackColor = Color.White; 
        foreach (TableCell cell in gridCustomer.HeaderRow.Cells) 
        { 
         cell.BackColor = gridCustomer.HeaderStyle.BackColor; 
        } 
        foreach (GridViewRow row in gridCustomer.Rows) 
        { 
         row.BackColor = Color.White; 
         foreach (TableCell cell in row.Cells) 
         { 
          if (row.RowIndex % 2 == 0) 
          { 
           cell.BackColor = gridCustomer.AlternatingRowStyle.BackColor; 
          } 
          else 
          { 
           cell.BackColor = gridCustomer.RowStyle.BackColor; 
          } 
          cell.CssClass = "textmode"; 
         } 
        } 

        gridCustomer.RenderControl(hw); 

        //style to format numbers to string 
        string style = @"<style> .textmode { } </style>"; 
        Response.Write(style); 
        Response.Output.Write(sw.ToString()); 
        Response.Flush(); 
        Response.End(); 
       } 
      } 
      catch (Exception ex) 
      { 
       ScriptManager.RegisterClientScriptBlock(this, this.GetType(), "alert", "alert('Exception Message: " + ex.Message.Replace("'", "").Replace("\"", "") + "');", true); 
      } 
     } 
+0

生成されたファイルの内容は、あなたが私のコードを変更することができ、.XLSに変換する方法.htmlを.XLS – Slai

+0

ではありませんので。 –

答えて

0

doodlereport nugetパッケージをご覧ください。私はあなたのために働くと思います。

0

以下のコードあなたの代わりにそれを使用することができますので、あなたのDataTableには、Excelに変換します:

public void CreateExcel(DataTable dt, string path) 
    { 

     try 
     { 
      if (File.Exists(path)) 
       File.Delete(path); 

      FileInfo newFile = new FileInfo(path); 
      using (ExcelPackage pck = new ExcelPackage(newFile)) 
      { 
       //Create the worksheet 
       ExcelWorksheet ws = pck.Workbook.Worksheets.Add("Query Result"); 

       //Load the datatable into the sheet, starting from cell A1. Print the column names on row 1 
       //ws.Cells["A1"].LoadFromDataTable(dt, true); 
       //ws.Cells["A1"].AutoFitColumns(); 

       int columnNumber = 0; 
       foreach (DataColumn dc in dt.Columns) 
       { 
        columnNumber++; 
        ws.Cells[1, columnNumber].Value = dc.ColumnName; 
       } 

       //Adding data of each row. 
       int rowNumber = 0; 
       foreach (DataRow rw in dt.Rows) 
       { 
        rowNumber++; 

        columnNumber = 0; 
        foreach (DataColumn dc in dt.Columns) 
        { 
         columnNumber++; 
         //Formating columns based on data types 
         if (rw[dc.ColumnName].GetType().ToString() == "System.Int32" || rw[dc.ColumnName].GetType().ToString() == "System.Double") 
          ws.Cells[rowNumber + 1, columnNumber].Style.Numberformat.Format = "0"; 
         else if (rw[dc.ColumnName].GetType().ToString() == "System.DateTime") 
          ws.Cells[rowNumber + 1, columnNumber].Style.Numberformat.Format = "yyyy-mm-dd hh:mm:ss"; 
         else if (rw[dc.ColumnName].GetType().ToString() == "System.Decimal") 
          ws.Cells[rowNumber + 1, columnNumber].Style.Numberformat.Format = "0.00"; 

         ws.Cells[rowNumber + 1, columnNumber].Value = rw[dc.ColumnName]; 
        } 
       } 


       //Format the header for columns 
       using (ExcelRange rng = ws.Cells["A1:Z1"]) 
       { 
        rng.Style.Font.Bold = true; 

       } 

       //Format Cells 
       using (ExcelRange col = ws.Cells[2, 1, dt.Rows.Count + 1, dt.Columns.Count + 1]) 
       { 
        col.Style.HorizontalAlignment = ExcelHorizontalAlignment.Right; 
        col.Style.VerticalAlignment = ExcelVerticalAlignment.Center; 
        col.AutoFitColumns(); 
       } 

       //Saving the excel sheet 
       pck.Save(); 
      } 

     } 
     catch (Exception ex) 
     { 
     } 



    } 
関連する問題