I was wondering if anyone had come across the following problem and had any ideas on how to resolve it: I\'m exporting data from a C# application (.NET 3.5) to Excel (2003)
I know it's late, but maybe someone need this in the future. It's not really for the performance but you can store it in a two-dimentional array first.
object[,] Values = new object[iGrid.Rows.Count, IGrid.Columns.Count];
for (int i = 0; i < alllogentry.Rows.Count; i++)
{
for (int j = 0; j < alllogentry.Columns.Count; j++)
{
if (alllogentry.Rows[i].Cells[j].Value != null)
{
Values[i, j] = alllogentry.Rows[i].Cells[j].Value.ToString();
}
else
{
Values[i, j] = " ";
}
}
}
This way number stays number and string stays string.
Also pass the information via bulk insert to excel not cell by cell. That was my code.
// Bulk Transfer
String MaxRow = (alllogentry.Rows.Count+6).ToString();
String MaxColumn = ((String)(Convert.ToChar(alllogentry.Columns.Count / 26 + 64).ToString() + Convert.ToChar(alllogentry.Columns.Count % 26 + 64))).Replace('@', ' ').Trim();
String MaxCell = MaxColumn + MaxRow;
//Format
worksheet.get_Range("A1", MaxColumn + "1").Font.Bold = true;
worksheet.get_Range("A1", MaxColumn + "1").VerticalAlignment = XlVAlign.xlVAlignCenter;
// Insert Statement
worksheet.get_Range("A7", MaxCell).Value2 = Values;