C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致。 |
您所在的位置:网站首页 › 导出的excel后缀是do › C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致。 |
* 0: 不检查文件扩展名和文件类型并绕过该函数的警告消息。 * 1: 检查文件扩展名和文件类型。如果它们不匹配会显示警告消息。 * 2: 检查文件扩展名和文件类型。如果它们不匹配不要打开该文件
方法二(提倡)
导致“文件格式与扩展名指定格式不一致”这个问题,是因为大多数人在导出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写的。然后就跟大家分享下咯 。~~哈哈
更多信息 如何确定 Excel SaveAs 方法的文件格式的值 在 Excel 中创建工作表,并将其保存在您想要的格式。请确保您在继续操作之前关闭该文件。发出下列命令在系统中: * First get an object reference to the Excel application oXL = CREATEOBJECT("Excel.Application") && starts excel * Open the worksheet created in step 1 (be sure to include * the full path and file name oXL.WorkBooks.Add("myfile.xls") * Retrieve the FileFormat nFileFormat = oXL.WorkBooks(1).FileFormat * Save the file under a new name with the same format oXL.WorkBooks(1).SaveAs("new.xls",nFileFormat) * Quit Excel oXL.Quit * Release the object reference RELEASE oXL |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |