參考:https://blog.csdn.net/g710710/article/details/21166453/
導致“文件格式與擴展名指定格式不一致”這個問題,是因為大多數人在導出excel文件的時候,都是默認保存excel的格式,
也就是直接workbook.Save(path)或者workbook.SaveAs(path).進而忽略了SaveAs方法里面的參數。與保存excel文件格式有
關的是它第二個參數FileForMat.
FileFormat
類型:System.Object XlFileFormat的值之一,指定保存文件時要使用的文件格式。對於原有文件,默認格式為最后一種
指定文件格式。對於新文件,默認格式為所用excel版本的格式。PS:當導出的excel文件的擴展名與所用excel版本的擴展名
不一致的時候就會出現“文件格式與擴展名指定格式不一致的”錯誤,當低版本打開excel文件時不但會提示這樣的錯誤,還
會是亂碼。
其他參數的解釋可以看下這篇文章http://blog.csdn.net/zyming0815/article/details/5939104。
解決辦法如下:
int FormatNum;//保存excel文件的格式
string Version;//excel版本號
Excel.Application Application = new Excel.Application();
Excel.Workbook workbook = (Excel.Workbook)Application.Workbooks.Add(Missing.Value);//激活工作簿
Excel.Worksheet worksheet =(Excel.Worksheet)workbook.Worksheets.Add(true);//給工作簿添加一個sheet
Version = Application.Version;//獲取你使用的excel 的版本號
if (Convert.ToDouble(Version) < 12)//You use Excel 97-2003
{
FormatNum = -4143;
}
else//you use excel 2007 or later
{
FormatNum = 56;
}
workbook.SaveAs(@"D:\MyExcel.xls", FormatNum);
