在Asp.Net中,导入Excel表格数据,通常有两种方法

 案例:

当我们在导入Excel表格数据时,在Asp.net中,通常有两种方式:

第一种:用Ole方法,将Excel表格导入数据库中(推荐使用此方法)

例子:

string FilePath = "c:/Andy.xls"  //定义读取表格的路径

//定义数据库连接

OleDbConnection sqlConnect=new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data     Source="+FilePath+";Extended Properties=Excel 8.0;IMEX=1/");
sqlConnect.Open();      
OleDbCommand sqlCmd=new OleDbCommand();
sqlCmd.Connection=sqlConnect;
sqlCmd.CommandType=CommandType.Text;

//sheet1$
string Sql="select * from [上报表1$]";
sqlCmd.CommandText=Sql;
OleDbDataAdapter adapter=new OleDbDataAdapter(sqlCmd);
System.Data.DataTable Rtable=new System.Data.DataTable("TExcel");

这样就可以利用Rtable要读取数据.

特别注意:一定要在数据库连接处,加上IMEX=1选项,否则,会出现在读取单元格数据时,某些单元格始终为空数据.

第二种:通过调用Excel.dll,读取Excel表格.(不推荐使用此方法)

例子:

.......................

Excel.Application objApp = new Excel.Application;

Excel.workbooks sbooks= objApp.workbooks;...............................

当时程序运行到

Excel.Application objApp = new Excel.Application;时,有时侯总要报'拒绝访问.............'错误.

我是这样处理的:

第一个需要设置的地方:

在你要操作的文件或文件夹(指导入Excel表格的所在目录)的属性的安全设置(如果目录中,没有安全设置,请在目录选项中设置),右键点击目录选择[属性],在[属性]对话框中选择第四项[security]或[安全],设置Everyone的访问权限为Full Control(完全控制),点击[Add]按钮,增加本机用户[Aspnet],设置为访问权限为Full control(完全控制).

第二个需要设置的地方:

在命令行运行DOS命令: dcomcnfg

在[Application]项目下选择[Microsoft Excel 应用程序],点击[属性]按钮,在应用程序属性对话框下选择第三项[Security],在三个单选按钮上都选择[Use Custom access permission],分别点击下面的[Edit]按钮,增加用户[Everyone](本级)和[Aspnet],并设置权限为[allow access].

这样把上述两个地方配置之后,就不会发生'拒绝访问.......'的错误.

强烈推荐使用第一种方法来导入Excel数据,因为使用第二种方法,又太多的局限性(例如:Office版本不同,调用的Excel.dll不同,还多系统进行权限设置)

如果想跟我直接交流的,请

QQ:229233976        MSN:wu_0426@msn.com 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值