關於asp.net C# 匯出Excel檔案 開啟Excel檔案格式與副檔名指定格式不一致的解決辦法

來源:互聯網
上載者:User

標籤:

轉載自阿姆的部落格 關於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寫的。然後就跟大家分享下咯。~~哈哈

關於asp.net C# 匯出Excel檔案 開啟Excel檔案格式與副檔名指定格式不一致的解決辦法

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.