asp.net<Web版> ---GridView 数据导出到excel表,系列问题<一>---导出的Excel文件格式与文件扩展名指定的格式不一致

    最近在做一个"考评系统",是用C# asp.net编写的Web文件。今天在实现一个功能"将页面显示的GridView中的数据,导出到Excel表格中"时遇到这样一个错误: C# 导出Excel文件 打开Excel文件格式与扩展名指定格式不一致。具体提示如图:

    

     根据问题提示,从网上找了一下问题答案


    产生此问题的原因

    我写入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: 检查文件扩展名和文件类型。如果它们不匹配不要打开该文件 

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值