• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

参考: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);


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Anders Hejlsberg谈C#、Java和C++中的泛型发布时间:2022-07-14
下一篇:
[C#]StringWriter实现的一个功能发布时间:2022-07-14
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap