C#儲存excel檔案時提示檔案格式與副檔名不匹配
如果儲存生成的excel檔案提示如下錯誤,
可以通過設定儲存excel格式來解決。
【例】
public static string xlsFilePath = @"D:\";//excel檔案存放路徑
/// <summary>
/// 匯出資料到excel檔案
/// </summary>
/// <param name="dt">要匯出的資料集</param>
/// <returns>生成的檔名</returns>
static public string ExporeToExcel(DataTable dt)
{
MSExcel.Application excelApp = null;
MSExcel.Workbooks wbks = null;
MSExcel._Workbook wbk = null;
try
{
string strDir = Directory.GetCurrentDirectory();
excelApp = new MSExcel.Application();
excelApp.Visible = false;//是開啟不可見
wbks = excelApp.Workbooks;
wbk = wbks.Add(true);
String version = excelApp.Version;//獲取你使用的excel 的版本號
int FormatNum;//儲存excel檔案的格式
if (Convert.ToDouble(version) < 12)//You use Excel 97-2003
{
FormatNum = -4143;
}
else//you use excel 2007 or later
{
FormatNum = 56;
}
object Nothing = Missing.Value;
MSExcel._Worksheet whs;
whs = (MSExcel._Worksheet)wbk.Sheets[1];//獲取第一張工作表
whs.Activate();
//寫入標題行
int rowIndex=1;
for (int col = 0; col < dt.Columns.Count; col++)
{
whs.Cells[rowIndex, col+1] = dt.Columns[col].Caption.ToString();
}
rowIndex++;
//寫入資料內容
foreach (DataRow row in dt.Rows)
{
for (int colIndex = 0; colIndex < dt.Columns.Count; colIndex++)
{
whs.Cells[rowIndex, colIndex + 1] = row[colIndex].ToString();
}
rowIndex++;
}
excelApp.DisplayAlerts = false;
//儲存excel檔案
string newFileName = xlsFilePath + "匯出的excel檔案" + DateTime.Now.ToString("yyyyMMddhhmmss") + ".xls";
wbk.SaveAs(newFileName, FormatNum);//儲存時候設定儲存格式
//關閉檔案
wbk.Close(false, Nothing, Nothing);
return newFileName;
}
catch (Exception e)
{
throw e;
}
finally
{
//wbks.Close();//關閉工作簿
excelApp.Quit();//關閉excel應用程式
System.Runtime.InteropServices.Marshal.ReleaseComObject(excelApp);//釋放excel程序
excelApp = null;
}
}