Создание Excel для больших данных в C # - PullRequest
0 голосов
/ 14 ноября 2018

Я пытаюсь создать лист Excel для больших данных о миллионе записей.Но при использовании приведенного ниже кода я ничего не получаю.Код зависает после строки: wb.SaveAs(MyMemoryStream);.Я использую закрытый XML для этой цели.Подскажите, пожалуйста, что можно сделать, чтобы сохранить большие данные в формате Excel.

Мой код:

private void DownloadExcel()
    {
        String Attachment = "attachment; filename=TestFile.xlsx";
        Response.ClearContent();
        DataTable dt = ds.Tables[0];


        using (XLWorkbook wb = new XLWorkbook())

        {
            wb.Worksheets.Add(dt, "Data");
            wb.Style.Font.FontName = "Courier New";
            // wb.Cell("A1:A+" + colCount + "").Style.Font.Bold = true;
            Response.Clear();
            Response.Buffer = true;
            Response.Charset = "";
            Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet";
            Response.AddHeader("content-disposition", Attachment);
            using (MemoryStream MyMemoryStream = new MemoryStream())
            {
                wb.SaveAs(MyMemoryStream);
                MyMemoryStream.WriteTo(Response.OutputStream);
                Response.Flush();
                Response.SuppressContent = true;  // Gets or sets a value indicating whether to send HTTP content to the client.
                HttpContext.Current.ApplicationInstance.CompleteRequest();
            }
        }
    }

Я в порядке с любой другой библиотекой, чтобы сохранить данные в виде XML.

1 Ответ

0 голосов
/ 14 ноября 2018

Вы можете попробовать любой из следующих подходов:

Подход 1: Сначала вам нужно создать шаблон Excel, а затем использовать следующую функцию.Он создаст новый Excel, используя ваш шаблон, и вставит данные в Excel, используя ACE.OLEDB.Это будет намного быстрее, но у вас нет контроля над форматированием.

   public static void CopyDataTableToExcel(DataTable dtExcel, String excelOutputTemplate, string outExcelPath)
    {
        File.Copy(excelOutputTemplate, outExcelPath, true);

        string qryFieldName = "";
        string qryFieldForCreate = "";
        string qryFieldValue = "";
        string qryFieldValueTemp = "";
        string qryInsert = "";

        for (int i = 0; i < dtExcel.Columns.Count; i++)
        {
            qryFieldName = qryFieldName + (qryFieldName.Trim() != "" ? ", " : "") + "[" + dtExcel.Columns[i].ColumnName + "]";
            qryFieldForCreate = qryFieldForCreate + (qryFieldForCreate.Trim() != "" ? ", " : "") +
                 "[" + dtExcel.Columns[i].ColumnName + "] varchar(255)";
        }

        // Establish a connection to the data source.
        System.Data.OleDb.OleDbConnection objConn = new System.Data.OleDb.OleDbConnection(
            "Provider=Microsoft.ACE.OLEDB.12.0;Data Source='" + outExcelPath + "';Extended Properties=\"Excel 12.0;HDR=YES;\"");
        objConn.Open();

        // Add two records to the table named 'MyTable'.
        System.Data.OleDb.OleDbCommand objCmd = new System.Data.OleDb.OleDbCommand();
        objCmd.Connection = objConn;

        qryInsert = "Create table InventorySheet (" + qryFieldForCreate + ")";
        objCmd.CommandText = qryInsert;
        objCmd.ExecuteNonQuery();

        for (int i = 0; i < dtExcel.Rows.Count; i++)
        {
            qryFieldValue = "";
            for (int j = 0; j < dtExcel.Columns.Count; j++)
            {
                qryFieldValueTemp = dtExcel.Rows[i][j].ToString();
                if (qryFieldValueTemp.Length > 255)
                {
                    qryFieldValueTemp = qryFieldValueTemp.Substring(qryFieldValueTemp.Length - 255);
                }
                qryFieldValue = qryFieldValue + (qryFieldValue.Trim() != "" ? ", '" : "'") + qryFieldValueTemp.Replace("'", "''") + "'";
            }

            //qryInsert = "Insert into [Sheet1$] Values (" + qryFieldValue + ")";
            qryInsert = "Insert into InventorySheet (" + qryFieldName + ") Values (" + qryFieldValue + ")";
            objCmd.CommandText = qryInsert;
            objCmd.ExecuteNonQuery();
        }

        // Close the connection.
        objConn.Close();
        MessageBox.Show("Exported successfully.");
    }

Подход 2: Сериализация таблицы данных в xml:

DataTable dtJobMetaData = yourDataSet.Tables["PDF"];
dtJobMetaData.WriteXml(xmlPath);
...