使用ASP.NET网页,我正在将一些数据导出到Excel电子表格(XLSX)。当我在Visual Studio中运行它时,代码可以正常运行(导出包含正确数据的XLSX文件),但是当部署到测试服务器上时,相同的代码会失败。
它没有抛出任何错误,只是导出一个空白的XLSX文件。
注意:在测试服务器上进行调试时,我发现数据被获取并且临时文件也被正确创建,但是数据没有被写入到临时文件中(奇怪的是它没有抛出任何错误)。
后来添加:
经过更多的研究,我发现小记录集(比如1000、2000条)没有问题。但是当尝试使用大约20K条记录时,我得到了一个空文件。
我已经为此苦恼了2天,希望有人能帮助我 :) ...
代码
它没有抛出任何错误,只是导出一个空白的XLSX文件。
注意:在测试服务器上进行调试时,我发现数据被获取并且临时文件也被正确创建,但是数据没有被写入到临时文件中(奇怪的是它没有抛出任何错误)。
后来添加:
经过更多的研究,我发现小记录集(比如1000、2000条)没有问题。但是当尝试使用大约20K条记录时,我得到了一个空文件。
我已经为此苦恼了2天,希望有人能帮助我 :) ...
代码
string templateFile = @"C:\Templates\ExportFile.xlsx";
string tempFileName = Path.Combine(@"C:\Temp\", Path.GetRandomFileName());
tempFileName = Path.ChangeExtension(tempFileName, ".xlsx");
File.Copy(templateFile, tempFileName);
List<Customer> customerList = FetchCustomers();
DataTable dataTableObj = new DataTable("Customers$");
dataTableObj.Columns.Add(new DataColumn("CustomerID"));
dataTableObj.Columns.Add(new DataColumn("FirstName"));
dataTableObj.Columns.Add(new DataColumn("LastName"));
dataTableObj.Columns.Add(new DataColumn("CreatedDate"));
foreach (Customer customerObj in customerList)
{
DataRow dataRowObj = dataTableObj.NewRow();
dataRowObj["CustomerID"] = customerObj.CustomerID;
dataRowObj["FirstName"] = customerObj.FirstName;
dataRowObj["LastName"] = customerObj.LastName;
dataRowObj["CreatedDate"] = customerObj.CreatedDate;
dataTableObj.Rows.Add(dataRowObj);
}
using (OleDbConnection oleDbConnectionObj = new OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=" + tempFileName + ";Extended Properties=\"Excel 12.0 Xml;HDR=YES;\""))
{
OleDbCommand insertCommand = new OleDbCommand();
insertCommand.Connection = oleDbConnectionObj;
insertCommand.CommandText = @"INSERT INTO [Customers$] ([CustomerID], [FirstName], [LastName], [CreatedDate]) VALUES (?, ?, ?, ?)";
insertCommand.Parameters.Add("CustomerID", OleDbType.Numeric, 0, "CustomerID");
insertCommand.Parameters.Add("FirstName", OleDbType.VarChar, 0, "FirstName");
insertCommand.Parameters.Add("LastName", OleDbType.VarChar, 0, "LastName");
insertCommand.Parameters.Add("CreatedDate", OleDbType.Date, 0, "CreatedDate");
DataSet dataSetObj = new DataSet();
dataSetObj.Tables.Add(dataTableObj);
OleDbDataAdapter dataAdapter = new OleDbDataAdapter();
dataAdapter.InsertCommand = insertCommand;
dataAdapter.Update(dataSetObj, "Customers$");
}
Response.Clear();
Response.Buffer = true;
Response.ContentType = "application/vnd.ms-excel";
Response.Charset = "";
Response.AddHeader("Content-Disposition", "attachment; filename=Customers.xlsx");
Response.WriteFile(tempFileName);
Response.Flush();
Response.End();