admin管理员组文章数量:1531958
2024年1月12日发(作者:)
关于 C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办法
导致“文件格式与扩展名指定格式不一致”这个问题,是因为大多数人在导出excel文件的时候,都是默认保存excel的格式,
也就是直接(path)或者(path).进而忽略了SaveAs方法里面的参数。与保存excel文件格式有
关的是它第二个参数FileForMat.
FileFormat
类型: XlFileFormat的值之一,指定保存文件时要使用的文件格式。对于原有文件,默认格式为最后一种
指定文件格式。对于新文件,默认格式为所用excel版本的格式。PS:当导出的excel文件的扩展名与所用excel版本的扩展名
不一致的时候就会出现“文件格式与扩展名指定格式不一致的”错误,当低版本打开excel文件时不但会提示这样的错误,还
会是乱码。
其他参数的解释可以看下这篇文章/zyming0815/article/details/5939104。
解决办法如下:
int FormatNum;//保存excel文件的格式
string Version;//excel版本号
ation Application = new ation();
ok workbook =
(ok)();//激活工作簿
eet worksheet =(eet)(true);//给工作簿添加一个sheet
Version = n;//获取你使用的excel 的版本号
if (le(Version) < 12)//You use Excel 97-2003
{
FormatNum = -4143;
}
else//you use excel 2007 or later
{
FormatNum = 56;
}
(@"D:", FormatNum);
如果想了解更多关于excel文件保存格式方面的知识,可以看下这篇文章比较详细。
/
后话:最近给公司的同事做EXCEL REPORT 就遇到了这样的问题,同事用的是2003版(我机子是2007版本),我用.NET生成的报表他打开是乱码,上网查大多数解决办法都是修改注册表什么的,觉得这个太麻烦了,也不可能去给每位同事去修改注册表啊。后来寻思SaveAs方法有那么多参数,应该有一个是指定保存格式的参数才对。哈哈,果然是。然后从FileFormat这个参数去查找资料,找到了上面推荐的那篇文章用VBA写的。然后就跟大家分享下咯 。~~哈哈
版权声明:本文标题:C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致的解决办 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/dianzi/1705031942a119955.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论