案例:
当我们在导入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