网络编程
位置:首页>> 网络编程>> Asp编程>> ASP向Excel导数据(图片)终结版 ASP操作Excel

ASP向Excel导数据(图片)终结版 ASP操作Excel

 来源:asp之家 发布时间:2011-03-25 10:48:00 

标签:ASP,Excel

相信有很多人有用程序向Excel导数据的需求, 且做过. 一般导出一些文本数据是很方便的, 可选方法很多, 比如拼接文本字符串存.cvs格式(以逗号与回车符分隔数据,默认用Excel打开), 比如把xls文件当成数据用SQL来操作 等等. 当需要导出图片数据的时候该怎么办? 这就需要使用Excel.Application对象.

实际上用Excel.Application可以做到OfficeExcel软件所能做到的全部操作, 功能相当强大. 但我们每个人学习精力有限, 不可能每个都对它很熟悉. 于是乎, 我选用了大量的关键词在百度与Google上搜索, 希望能得到一些有价值的东西. 但找来找去, 没发现一篇是完整版, 大多数是询问的, 而且代码中包含诸多的明显错误与功能上的缺性. 值得批评的是, 大量站点直接复制他人站点文章, 而且还是劣质文章. 诶, 不找也罢! 佛曰 我不下地狱谁下地狱, 于是我给大家把这个工作给做了.

我首先找了个VBA的手册合集, 还好它是chm格式. 打开其中的Vbaexcelxl10.chm, 嗯, 不错不错, 确实是一个不错的手册, 但是, 它不是一个教程, 欲哭无泪… 没办法, 只好硬头皮看下去. 手册毕竟是手册, 不会一把些细节上的便捷操作提出来, 也不会把各部分内容的逻辑关联讲得很完整. 经过我仔细的分析, 大胆的预测, 周密的思考, 大量的试验, 上刀山,下火锅, 不对,是火海, 好不容易才把它完美的实现了. 现在, 又把它连夜传到Web630.Net上, 仅仅只是希望大家记住这个站点, 同时希望各技术站多点原创文章, 为中国的程序业发展做点贡献.

代码如下:

<% 
Rem 初始化ExcelApplication的工作环境 
Dim ExcelApp,eBook,eSheet 
Set ExcelApp = CreateObject(”Excel.Application”) ‘建立Excel对象 
ExcelApp.DisplayAlerts=false ‘不显示警告 
ExcelApp.Application.Visible=false ‘不显示界面 

Rem 初始化Excel数据 
‘ExcelApp.Workbooks.Open(Server.MapPath(”zzz.xls”)) ‘打开Excel工作本,可替换下面一行 
Set eBook=ExcelApp.Workbooks.Add ‘新建Excel工作本 
Set eBook=ExcelApp.Workbooks(1) ‘引用第一个工作本 
set eSheet = eBook.Worksheets(1) ‘引用第一个工作表 

Rem 数据导入 
Dim i,img 
i = 1 
For i=1 To 5 
eSheet.Cells(i,1).Value=”字段一”&i 
eSheet.Cells(i,2).Value=”字段二”&i 
eSheet.Cells(i,3).Value=”字段三”&i 
eSheet.Cells(i,4).Select ‘选择第i行第4个单元单元格 
Set img=eSheet.Pictures.Insert(Server.MapPath(”people.jpg”)) ‘在上述位置插入图片,并得到图片的引用 
img.Top=img.Top+2 ‘调整图片位置,下同, 否则它会压住表格边线 
img.Left=img.Left+2 ‘单位是磅 
eSheet.Rows(i).RowHeight=img.Height+4 ‘调整当前行的高度,让它自动与图片高度相同 
Next 

Rem 保存上述所做的工作 
‘eBook.Save ‘如果是打开已经存在的Excel文件,则可选用这行来代替下面一行 
eBook.SaveAs Server.MapPath(”zzz.xls”) 
Set eSheet=Nothing 
Set eBook=Nothing 
‘ExcelApp.Quit ‘一定要退出, 否则Excel的进程留在操作系统中. 
set ExcelApp = Nothing 
%>

ASP向Excel读取或写入数据时, 比较简洁的一种方法是把Excel当作数据库使用SQL语句来操作. 网上很多地方都有相关的文章, 本文仅作为《ASP向Excel导数据(图片)终结版》的辅助资料给大家参考.

代码如下:

<% 
Dim conn,rs,sql 
Sub DBOpen() 
Dim db : db=Server.MapPath(”zzz.xls”) 
Set conn=Server.CreateObject(”Adodb.Connection”) 
On Error Resume Next 
conn.Open “Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=”"Excel 8.0;HDR=YES”";Data Source=” & db 
Rem HDR 默认为YES,表示第一行作为字段名, 否则视它为内容 
Rem 对于Excel2007,而应为: “Provider=Microsoft.ACE.OLEDB.12.0; Extended Properties=Excel 12.0;Data Source=xxx.xlsx;” 
If Err.Number<>0 then 
Err.Clear 
Response.Write(”<h1>The Database link is ERROR</h1>”) 
Response.End() 
End If 
On Error GoTo 0 
End Sub 
Sub DBClose() 
If IsNotBlank(conn) Then 
conn.Close() 
Set conn=Nothing 
End If 
End Sub 
Function IsNotBlank(ByRef TempVar) 
IsBlank = True 
Select Case VarType(TempVar) 
Case 0,1 ‘Empty & Null 
IsBlank = False 
Case 9 ‘Object 
If TypeName(TempVar) = “Nothing” Or TypeName(TempVar) = “Empty” Then 
IsBlank = False 
End If 
End Select 
End Function 

Call DBOpen() 
sql=”SELECT * FROM [Sheet1$]” ‘注意表名的写法, 需要在工作表名的后面加符号$ 
Set rs=conn.Execute(sql) 
While Not rs.Eof 
Response.Write(rs(0)&”, “) 
Response.Write(rs(1)&”, “) 
Response.Write(rs(2)&”<br />”&VbCrLf) 
rs.Movenext 
Wend 
rs.Close : Set rs=Nothing 
Call DBClose() 
%> 

 

0
投稿

猜你喜欢

  • 请问鼠标移过去就出现二级菜单代码怎么写啊    <head><style type="tex
  • 回想自己从事Web方面的开发已经有6-7年,对于各种Web技术都已经非常熟悉.可是,身为程序员的我对于制作Web表单界面的事着实心痛。心痛1
  • It's well-known.Microsoft SQL Server 7.0增加了一个语句top,可以限制返回的记录数。但是在使
  • 我把数据库操作类整理了一下,它包含了常用的数据库操作,由三种方式:简单的SQL拼接字符串的形式,SQL语句使用参数的形式和存储过程的形式,每
  • 昨天群里介绍了一个专门帮你PS图片的网站。吐司网。网站在图片的预览处理上有点意思。当鼠标经过图片,显示为处理过的图片。这样大家能很清晰的对比
  • conn.execute、rs.open之间的差别,conn.execute、rs.open、command.execute方法用法大大不同
  • 内容摘要:现在InterNet 越来越成为生活中不可或缺的一部分,制作网页的动态语言也越来越多,主要流行的有以下几种,ASP,PH
  • 先把我的browser信息说明一下:这是在opera里about中显示的“浏览器识别”Opera/9.62 (Windows NT 5.1;
  •  <% set conn=server.createobject("adodb.connect
  •     不知道算不算DW4的大BUG. DW4实际的运行如下: 读注册表中HKEY_CURRENT_USER/
  • 今早打开 腾讯ISD的博客 ,看到一篇新的文章,《迷你屋视觉规范简介》,赶紧看了来学习。不过给我抓到问题咯,臭鱼不介意我在这说下吧:这套规范
  • 一直以来,ACCESS数据库中的申报数据在分公司与总公司之间传递,用EXCEL或DBASE、TXT甚至ACCESS等格式,我总觉得不太理想。
  • 如果MySQL服务器启用了二进制日志,你可以使用mysqlbinlog工具来恢复从指定的时间点开始 (例如,从你最后一次备份)直到现在或另一
  • Function Moneynm(n,m)        &
  • 1、可以控制左横向滚动还是右横向滚动。2、鼠标悬停上时暂停滚动,移开后恢复滚动。3、间歇时间按需调整,但不要低于容器向左/右移动的时间。JA
  • 经常看见MOP上有人贴那种动态的图片,就是把一个字符串作为参数传给一个 * 页,就会生成一个带有这个字符串的图片,这个叫做文字水印。像什么原
  • 译者:AlphaImageLoader是一个让IE6正常显示PNG32时要用到的一个滤镜,但它在使用中也会产生一系列的问题,本文对使用Alp
  • 第一种方法:  代码如下:/* 创建链接服务器 */ exec sp_addlinkedserver 'srv_lnk&#
  • Insert 和 Update假设现在你要把下面的数据插入到数据库中.ID = 3TheDate=mktime(0,0,0,8,31,200
  • 很佩服国外一些前端开发人员对待学问的研究精神,他们很善于总结发现。看到一篇关于安全字体List of Web Safe Fonts的文章,里
手机版 网络编程 asp之家 www.aspxhome.com