您的位置:首页 > 编程语言 > C#

C# 保存Excel文件 ( 打开Excel文件格式与扩展名指定格式不一致)

2016-12-27 12:51 453 查看
之前有操作Excel的一些编程,保存我们想要的Excel文件格式就是距离成功的最后一步!

我一开始还一直想着把每个文件格式对应api中的xlFileFormat的参数找到。。。以下方法很好,作为新手,我肯定要分享记录下来。

转载自:http://blog.csdn.net/g710710/article/details/21166453

!!!如何确定 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

以下是转载的文章的其他内容,不关心的就可以不看了。

方法一(不提倡)

产生此问题的原因:

    我写入Excel的不是正常的Excel格式,说白了就是我用Response.WriteFile("k:\\StudentMarks.xls");生成的Excel根本不是Excel,只不过扩展名是xls而已,这是Excel的安全问题,所以打开的时候会提示"您尝试打开的**.xls文件格式与文件扩展名指定的格式不一致"。

    本人电脑安装的是Office2010,使用的操作系统是64位 WIN7旗舰版。

   

这里采用"修改注册表的方法"解决此问题,这并没从根上解决问题:

1、打开注册表编辑器方法:开始 -> 运行 -> 输入regedit -> 确定

2、找到注册表子项HKEY_CURRENT_USER\Software\Microsoft\Office\12.0\Excel\Security

3、在右侧空白处点击鼠标右键,选择“新建 -> DWORD值(D)”,输入“ExtensionHardening”点击确定。

4、用鼠标右键点击ExtensionHardening,然后单击“修改(M)”,在数值数据中填写“0”即可确定。

5、关闭注册表编辑器,再次打开xls文件看看是不是提示是不是不见了?

小知识:ExtensionHardening设置的值的数据设置:

 * 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 c# SaveAs XlFileFormat
相关文章推荐