ASP操作Excel技术总结[转载收藏]
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了ASP操作Excel技术总结[转载收藏],小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5077字,纯文字阅读大概需要8分钟。
内容图文
![ASP操作Excel技术总结[转载收藏]](/upload/InfoBanner/zyjiaocheng/797/dc01b4cf33204e528d657cae81f7c6c0.jpg)
目录?
一、 环境配置?
二、 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、 改变单元格文字颜色
?objExcelSheet.Cells(3,1).Font.Color=vbred
4、 单元格四周画线条?
objExcelSheet.Cells(3.1).Borders(1).LineStyle?=1
objExcelSheet.Cells(3.1).Borders(2).LineStyle?=1
objExcelSheet.Cells(3.1).Borders(3).LineStyle?=1
objExcelSheet.Cells(3.1).Borders(4).LineStyle?=1
???????区域中间画线条
objExcelSheet.Range(“A1:G7”).Borders(7).LineStyle?=1
objExcelSheet.Range(“A1:G7”).Borders(8).LineStyle?=1
8、 单元格设定背景色?
objExcelSheet.Cells(3.1).Interior.colorindex=17
9、 合并单元格?
objExcelSheet.Range(“A1:G7”).Merge
10、 设置左右对齐方式
2?left???3?middle???4??right
objExcelSheet.Range("A1").HorizontalAlignment?=?2
11、 设置上下对齐方式
2?为居中
objExcelSheet.Range("A1")..VerticalAlignment?=?2
四、 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”,保证每次程序执行完不留下死进程。
转载于:https://www.cnblogs.com/guoxiaowen/archive/2010/04/21/1717433.html
内容总结
以上是互联网集市为您收集整理的ASP操作Excel技术总结[转载收藏]全部内容,希望文章能够帮你解决ASP操作Excel技术总结[转载收藏]所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。