admin管理员组

文章数量:1531760

2024年5月22日发(作者:)

目录

一、 环境配置

二、 ASP对Excel的基本操作

三、 ASP操作Excel生成数据表

四、 ASP操作Excel生成Chart图

五、 服务器端Excel文件浏览、下载、删除方案

六、 附录

正文

一、 环境配置

服务器端的环境配置从参考资料上看,微软系列的配置应该都行,即:

1.Win9x+PWS+Office

2.Win2000 Professional+PWS+Office

3.Win2000 Server+IIS+Office

目前笔者测试成功的环境是后二者。Office的版本没有特殊要求,考虑到客户机配置的不确

定性和下兼容特性,建议服务器端Office版本不要太高,以防止客户机下载后无法正确显示。

服务器端环境配置还有两个偶然的发现是:

1. 笔者开发机器上原来装有金山的WPS2002,结果Excel对象创建始终出现问题,卸

载WPS2002后,错误消失。

2. 笔者开发ASP代码喜欢用FrontPage,结果发现如果FrontPage打开(服务器端),

对象创建出现不稳定现象,时而成功时而不成功。扩展考察后发现,Office系列的软件如果

在服务器端运行,则Excel对象的创建很难成功。

服务器端还必须要设置的一点是COM组件的操作权限。在命令行键入“DCOMCNFG”,则

进入COM组件配置界面,选择Microsoft Excel后点击属性按钮,将三个单选项一律选择

自定义,编辑中将Everyone加入所有权限。保存完毕后重新启动服务器。

客户端的环境配置没发现什么特别讲究的地方,只要装有Office和IE即可,版本通用的好

象都可以。

二、 ASP对Excel的基本操作

1、 建立Excel对象

set objExcelApp = CreateObject( "ation ")

yAlerts = false 不显示警告

e = false 不显示界面

2、 新建Excel文件

set objExcelBook = WorkBook

set objExcelSheets = eets

set objExcelSheet = (1)

3、 读取已有Excel文件

strAddr = h( ". ")

(strAddr & " ")

set objExcelBook = WorkBook

set objExcelSheets = eets

set objExcelSheet = (1)

4、 另存Excel文件

strAddr & " "

5、 保存Excel文件

(笔者测试时保存成功,页面报错。)

6、 退出Excel操作

一定要退出

set objExcelApp = Nothing

三、 ASP操作Excel生成数据表

1、 在一个范围内插入数据

( "B3:k3 ").Value = Array( "67 ", "87 ", "5 ",

"45 ", "45 ", "54 ", "54 ", "10 ")

2、 在一个单元格内插入数据

(3,1).Value= "Internet Explorer "

3、 选中一个范围

4、 单元格左边画粗线条

5、 单元格右边画粗线条

6、 单元格上边画粗线条

7、 单元格下边画粗线条

8、 单元格设定背景色

9、 合并单元格

10、 插入行

11、 插入列

四、 ASP操作Excel生成Chart图

1、 创建Chart图

2、 设定Chart图种类

ype = 97

注:二维折线图,4;二维饼图,5;二维柱形图,51

3、 设定Chart图标题

le = True

= "A test Chart "

4、 通过表格数据设定图形

rceData ( "A1:k5 "),1

5、 直接设定图形数据(推荐)

ies

Collection(1).Name = "= " "333 " " "

Collection(1).Values = "={1,4,5,6,2} "

6、 绑定Chart图

on 1

7、 显示数据表

aTable = True

8、 显示图例

"9 ", "7 ",

gendKey = True

五、 服务器端Excel文件浏览、下载、删除方案

浏览的解决方法很多,“=”,“Navigate”,“ct”都可以实现,建

议用客户端的方法,原因是给服务器更多的时间生成Excel文件。

下载的实现要麻烦一些。用网上现成的服务器端下载组件或自己定制开发一个组件是比较好

的方案。另外一种方法是在客户端操作Excel组件,由客户端操作服务器端Excel文件另存

至客户端。这种方法要求客户端开放不安全ActiveX控件的操作权限,考虑到通知每个客户

将服务器设置为可信站点的麻烦程度建议还是用第一个方法比较省事。

删除方案由三部分组成:

A: 同一用户生成的Excel文件用同一个文件名,文件名可用用户ID号或SessionID号

等可确信不重复字符串组成。这样新文件生成时自动覆盖上一文件。

B: 在文件中设置Session_onEnd事件激发时,删除这个用户的Excel暂存文

件。

C: 在文件中设置Application_onStart事件激发时,删除暂存目录下的所有文

件。

注:建议目录结构 Src 代码目录 Templet 模板目录 Temp 暂存目录

六、 附录

出错时Excel出现的死进程出现是一件很头疼的事情。在每个文件前加上“On Error

Resume Next”将有助于改善这种情况,因为它会不管文件是否产生错误都坚持执行到

“”,保证每次程序执行完不留下死进程。

在ASP中怎样把EXCEL导入ACCESS

<%

Dim cn,oConn,connstr

'打开XLS.

Set cn = Object("tion")

er = ".4.0 "

tionString = "Data Source=" & h("") & ";" & _

"Extended Properties=Excel 8.0;"

'打开MDB.

connstr="DBQ="+h("")+";DefaultDir=;DRIVER={Microsoft Access

Driver (*.mdb)};"

set oConn=Object("TION")

connstr

'读取数据.

set rsRead=Object("set")

"select * from [Sheet1$]",cn,1,1

do until

'写入数据库.

e("Insert into users(userid,password)Values('"& ("userid")&"','"

&("password") & "')" )

xt

loop

%>

数据库

表users

id,uesrid,password

Excel文件

数据

userid password

wang w521

zhange z254

hong h112

'================!!!!ASP读取EXCEL注事项!!!!======================

'i)将Excel97或Excel2000生成的XLS文件(book)看成一个数据库,其中的每一个工作表

(sheet)看成数据库表

'ii)ADO假设Excel中的第一行为字段名.所以你定义的范围中必须要包括第一行的内容

'iii)Excel中的行标题(即字段名)不能够包含数字. Excel的驱动在遇到这种问题时就会出错

的。例如你的行标题名为“F1”

'iiii)如果你的Excel电子表格中某一列同时包含了文本和数字的话,那么Excel的ODBC驱动

将不能够正常, 处理这一行的数据类型,你必须要保证该列的数据类型一致

'====================================================

本文标签: 文件操作服务器端配置下载