關於asp.net C# 導出Excel文件 打開Excel文件格式與擴展名指定格式不一致的解決辦法


導致“文件格式與擴展名指定格式不一致”這個問題,是因為大多數人在導出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);

如果想了解更多關於excel文件保存格式方面的知識,可以看下這篇文章比較詳細。

http://www.rondebruin.nl/saveas.htm

后話:最近給公司的同事做EXCEL REPORT 就遇到了這樣的問題,同事用的是2003版(我機子是2007版本),我用.NET生成的報表他打開是亂碼,上網查大多數解決辦法都是修改注冊表什么的,覺得這個太麻煩了,也不可能去給每位同事去修改注冊表啊。后來尋思SaveAs方法有那么多參數,應該有一個是指定保存格式的參數才對。哈哈,果然是。然后從FileFormat這個參數去查找資料,找到了上面推薦的那篇文章用VBA寫的。然后就跟大家分享下咯。~~哈哈


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM