-----转载:http://blog.csdn.net/sgear/article/details/7663502

关于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) < )//You use Excel 97-2003
{
FormatNum = -;
}
else//you use excel 2007 or later
{
FormatNum = ;
}
workbook.SaveAs(@"D:\MyExcel.xls", FormatNum);

如果想了解更多关于excel文件保存格式方面的知识,可以看下这篇文章比较详细。

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

后话:最近给公司的同事做EXCEL REPORT 就遇到了这样的问题,同事用的是2003版(我机子是2007版本),我用.NET生成的报表他打开是乱码,上网查大多数解决办法都是修改注册表什么的,觉得这个太麻烦了,也不可能去给每位同事去修改注册表啊。后来寻思SaveAs方法有那么多参数,应该有一个是指定保存格式的参数才对。哈哈,果然是。然后从FileFormat这个参数去查找资料,找到了上面推荐的那篇文章用VBA写的。然后就跟大家分享下咯 。~~哈哈

最新文章

  1. 新应用上线 Snippet
  2. Git命令使用总结
  3. mysql 查看数据库、表的基本命令
  4. Register DLL Assembly Gacutil.exe(全局程序集缓存工具)
  5. [公告]这里的博客将不再更新,最新博客请移步至blog.coderzh.com
  6. 安装VVDocumenter-Xcode-master (Xcode 7.1)的过程
  7. Linux系统Shutdown命令定时关机详解
  8. Educational Codeforces Round 1 C. Nearest vectors 极角排序
  9. UESTC_Judgment Day CDOJ 11
  10. SICP的一些个人看法
  11. UWSGI配置文件---ini和xml示例
  12. js判断ip地址,子网掩码,网关的逻辑性检查
  13. vue实现图书管理demo
  14. (七十五)CoreLocation(一)在iOS7和iOS8设备上获取授权
  15. CICD - Teamcity 配置之二:SSIS Package 自动部署
  16. Fernflower 反编译.class文件
  17. Gym - 101375H MaratonIME gets candies 交互题
  18. HTML 转 PDF 之 wkhtmltopdf 工具精讲
  19. keras、 tensor flow 教程
  20. C++ 并发编程 01 线程api

热门文章

  1. requirejs 合并方案
  2. Jersey Politics
  3. java学习之面向对象概念
  4. SendMessage和PostMessage区别以及WPARAM 和 LPARAM区别
  5. 数据结构(虚树,动态规划):HNOI 2014 世界树
  6. 数据结构(主席树):HDU 4729 An Easy Problem for Elfness
  7. 【动态规划】Codeforces 698A &amp; 699C Vacations
  8. Container With Most Water——LeetCode
  9. 吐血原创:mini2440和win7笔记本利用无路由功能的交换机共享上网(使用x-router软路由)
  10. 数学概念——F 概率(经典问题)birthday paradox