ASP操作Excel技术总结

作者:无名 - ASP基础 -

目录 

一、 环境配置 

二、 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("Excel.Application")  

objExcelApp.DisplayAlerts = false 不显示警告  

objExcelApp.Application.Visible = false 不显示界面
 
2、 新建Excel文件  

以下是引用片段:
objExcelApp.WorkBooks.add  

set objExcelBook = objExcelApp.ActiveWorkBook  

set objExcelSheets = objExcelBook.Worksheets  

set objExcelSheet = objExcelBook.Sheets(1)
 
3、 读取已有Excel文件  

以下是引用片段:
strAddr = Server.MapPath(".")  

objExcelApp.WorkBooks.Open(strAddr & "\Templet\Table.xls")  

set objExcelBook = objExcelApp.ActiveWorkBook  

set objExcelSheets = objExcelBook.Worksheets  

set objExcelSheet = objExcelBook.Sheets(1) 

4、 另存Excel文件  

以下是引用片段:
objExcelBook.SaveAs strAddr & "\Temp\Table.xls"
 
5、 保存Excel文件 

以下是引用片段:
objExcelBook.Save (笔者测试时保存成功,页面报错。)  

6、 退出Excel操作 

以下是引用片段:
objExcelApp.Quit 一定要退出  

set objExcelApp = Nothing  

三、 ASP操作Excel生成数据表 

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

以下是引用片段:
objExcelSheet.Range("B3:k3").Value = Array("67", "87", "5", "9", "7", "45", "45", "54", "54", "10")  

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

以下是引用片段:
objExcelSheet.Cells(3,1).Value="Internet Explorer"
 
3、 选中一个范围 

4、 单元格左边画粗线条 

5、 单元格右边画粗线条 

6、 单元格上边画粗线条 

7、 单元格下边画粗线条 

8、 单元格设定背景色 

9、 合并单元格 

10、 插入行 

11、 插入列 

四、 ASP操作Excel生成Chart图 

1、 创建Chart图 

以下是引用片段:
objExcelApp.Charts.Add  

2、 设定Chart图种类 

以下是引用片段:
objExcelApp.ActiveChart.ChartType = 97  

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

3、 设定Chart图标题  

以下是引用片段:
objExcelApp.ActiveChart.HasTitle = True  

objExcelApp.ActiveChart.ChartTitle.Text = "A test Chart" 

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

以下是引用片段:
objExcelApp.ActiveChart.SetSourceData objExcelSheet.Range("A1:k5"),1
 
5、 直接设定图形数据(推荐) 

以下是引用片段:
objExcelApp.ActiveChart.SeriesCollection.NewSeries  

objExcelApp.ActiveChart.SeriesCollection(1).Name = "=""333"""  

objExcelApp.ActiveChart.SeriesCollection(1).Values = "={1,4,5,6,2}"  

6、 绑定Chart图  

以下是引用片段:
objExcelApp.ActiveChart.Location 1 

7、 显示数据表  

以下是引用片段:
objExcelApp.ActiveChart.HasDataTable = True
 
8、 显示图例 

以下是引用片段:
objExcelApp.ActiveChart.DataTable.ShowLegendKey = True  

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

浏览的解决方法很多,“Location.href=”,“Navigate”,“Response.Redirect”都可以实现,建议用客户端的方法,原因是给服务器更多的时间生成Excel文件。 

下载的实现要麻烦一些。用网上现成的服务器端下载组件或自己定制开发一个组件是比较好的方案。另外一种方法是在客户端操作Excel组件,由客户端操作服务器端Excel文件另存至客户端。这种方法要求客户端开放不安全ActiveX控件的操作权限,考虑到通知每个客户将服务器设置为可信站点的麻烦程度建议还是用第一个方法比较省事。 

删除方案由三部分组成: 

A: 同一用户生成的Excel文件用同一个文件名,文件名可用用户ID号或SessionID号等可确信不重复字符串组成。这样新文件生成时自动覆盖上一文件。 

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

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

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

六、 附录 

出错时Excel出现的死进程出现是一件很头疼的事情。在每个文件前加上“On Error Resume Next”将有助于改善这种情况,因为它会不管文件是否产生错误都坚持执行到“Application.Quit”,保证每次程序执行完不留下死进程。

IT人知识库 原文地址:http://www.itpeo.net/12728/370728.html





显示在线人数

<%NowUrl=request.servervariables("HTTP_REFERER")UserName ... ...

生成静态页大全[ASP/PHP/ASPX]

ASP生成静态网页的方法   随着网站访问量的加大,每次从数据库读取都是以效率作为代价的,很多用ACCESS作数据库的更... ...

让ASP搭配MYSQL

让ASP搭配MYSQL 所需要工具    mysql-4.1.11-win32  ... ...

E-mail表单递交

<HTML><HEAD><META http-equiv='Content-Type' c... ...

替换数据库内容

<%'####################################'替换数据库内容 lamking 2... ...

怎么远程调用ACCESS数据库[要求加精!!]

使用了TCP/IP,ADO及XML(需要安装Microsoft XML 4.0。)。分服务器和客户端两部分,服务器可以多... ...

无组件生成缩略图

网上有不少生成缩略图的ASP组件。若你的虚拟空间不支持注册新组件,可能会感觉自己的网站失色不少。心晴不才,结合网上资源写... ...

多附件上传组件演示

table{ FILTER: progid:DXImageTransform.Microsoft.Shadow(... ...

asp实现无限级分类的方法js版

MenuArr=new Array()MenuLenArr=new Array()SubMenuArr=new Arra... ...

asp 防止SQL注入代码

把下面代码复制到每个文件头部就可以防止SQL注入了,写程序安全最重要 :) <% Dim Fy_Url,... ...

几个常用的ASP函数

========取得带端口的URL,推荐使用================  Function G... ...

ASP中Request对象获取客户端数据的顺序(容易忽略)

在ASP中Request对象是获取客户端提交数据的一个很重要的对象,大家对他也是非常熟悉了。虽然如此,还是经常有人问我下... ...

ASP连接11种数据库语法总结

经常使用到有关数据库的操作。包括连接代码、SQL命令等等,又不曾刻意去记忆它们(我本人是不愿意去记这东东),所以常常在用... ...

asp中Byval与Byref的区别

文件名称: ByVal.asp ByRef.asp 具体代码: <%Sub TestMain()... ...

asp组件编写准备工作

最近在尝试用组件写asp,一些心得如下,不对之处请指正 经常要重启IIS,所以需要一个批处理的文件,将下面两行代码存为x... ...

保证asp叶面一定不会出现乱码 UTF8

保证asp叶面一定不会出现乱码的代码应该是这样的:(假定是UTF-8的叶子) <%@ CODE... ...

经典的分页完整程序+注释

在前面我们已经给大家讲了分页程序,在这里再给大家提供一个,分析一下也许有新的收获. 代码如下:<% '以下程序是... ...

vbcrlf的意思

常数         &nbs... ...

js+asp总结

一直在用JS写ASP,也不是特别原因,只是当初学的是JS,后来学ASP时知道ASP也可以用JS写,就没去学VBS.前几个... ...

解决rs.absolutepage=-1的问题

有时候在做asp的分页程序的时候会遇到无法分页的情况,就试着把rs.absolutepage打印出来结果却一直为-1。 ... ...