中国站长下载-为中国站长提供最好最全的建站资源! 首 页发布资源有事留言繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:中国站长下载 -> 文章中心 -> 网页编程 -> .NET编程 -> 文章内容  虚拟主机 域名注册 退出登录 用户管理
栏目导航
· ASP编程 · .NET编程
· PHP编程 · JSP编程
· CGI 专区
热门文章
· sndvol32 - sndvol3...
· [组图] FLASH:《大话李白》...
· 个人网站到底能赚多...
· [图文] Rundll.exe是病毒吗...
· [组图] Flash:制作MV
· 价值12万元的网站SE...
· 网站创业者,你需要...
· 一个成功的网站设计...
· [图文] FLASH:韩国导航条解...
· 中国网站的赚钱模式...
相关文章
· ASP导出Excel数据的...
· Linux下安PHP,APACH...
ASP导出Excel数据的四种方法(1)
作者:不详  来源:不详  发布时间:2006-8-14 9:17:49  发布人:chinazhan

 减小字体 增大字体

     一、使用OWC
  
    什么是OWC?
  
    OWC是Office Web Compent的缩写,即Microsoft的Office Web组件,它为在Web中绘制图形提供了灵活的同时也是最基本的机制。在一个intranet环境中,如果可以假设客户机上存在特定的浏览器和一些功能强大的软件(如IE5和Office 2000),那么就有能力利用Office Web组件提供一个交互式图形开发环境。这种模式下,客户端工作站将在整个任务中分担很大的比重。
  
  
  <%Option Explicit
  Class ExcelGen
  Private obJSPreadsheet
  Private iColOffset
  
  Private iRowOffset
  Sub Class_Initialize()
  Set objSpreadsheet = Server.CreateObject("OWC.Spreadsheet")
  iRowOffset = 2
  iColOffset = 2
  End Sub
  
  Sub Class_Terminate()
  Set objSpreadsheet = Nothing 'Clean up
  End Sub
  
  Public Property Let ColumnOffset(iColOff)
  If iColOff > 0 then
  iColOffset = iColOff
  Else
  iColOffset = 2
  End If
  End Property
  
  Public Property Let RowOffset(iRowOff)
  If iRowOff > 0 then
  iRowOffset = iRowOff
  Else
  iRowOffset = 2
  End If
  End Property Sub GenerateWorksheet(objRS)
  'Populates the Excel worksheet based on a Recordset's contents
  'Start by displaying the titles
  If objRS.EOF then Exit Sub
  Dim objField, iCol, iRow
  iCol = iColOffset
  iRow = iRowOffset
  For Each objField in objRS.Fields
  objSpreadsheet.Cells(iRow, iCol).Value = objField.Name
  objSpreadsheet.Columns(iCol).AutoFitColumns
  '设置Excel表里的字体
  objSpreadsheet.Cells(iRow, iCol).Font.Bold = True
  objSpreadsheet.Cells(iRow, iCol).Font.Italic = False
  objSpreadsheet.Cells(iRow, iCol).Font.Size = 10
  objSpreadsheet.Cells(iRow, iCol).Halignment = 2 '居中
  iCol = iCol + 1
  Next 'objField
  'Display all of the data
  Do While Not objRS.EOF
  iRow = iRow + 1
  iCol = iColOffset
  For Each objField in objRS.Fields
  If IsNull(objField.Value) then
  objSpreadsheet.Cells(iRow, iCol).Value = ""
  Else
  objSpreadsheet.Cells(iRow, iCol).Value = objField.Value
  objSpreadsheet.Columns(iCol).AutoFitColumns
  objSpreadsheet.Cells(iRow, iCol).Font.Bold = False
  objSpreadsheet.Cells(iRow, iCol).Font.Italic = False
  objSpreadsheet.Cells(iRow, iCol).Font.Size = 10
  End If
  iCol = iCol + 1
  Next 'objField
  objRS.MoveNext
  Loop
  End Sub Function SaveWorksheet(strFileName)
  
  'Save the worksheet to a specified filename
  On Error Resume Next
  Call objSpreadsheet.ActiveSheet.Export(strFileName, 0)
  SaveWorksheet = (Err.Number = 0)
  End Function
  End Class
  
  Dim objRS
  Set objRS = Server.CreateObject("ADODB.Recordset")
  objRS.Open "SELECT * FROM xxxx", "Provider=SQLOLEDB.1;Persist Security
  
  Info=True;User ID=xxxx;Password=xxxx;Initial Catalog=xxxx;Data source=xxxx;"
  Dim SaveName
  SaveName = Request.Cookies("savename")("name")
  Dim objExcel
  Dim ExcelPath
  ExcelPath = "Excel\" & SaveName & ".xls"
  Set objExcel = New ExcelGen
  objExcel.RowOffset = 1
  objExcel.ColumnOffset = 1
  objExcel.GenerateWorksheet(objRS)
  If objExcel.SaveWorksheet(Server.MapPath(ExcelPath)) then
  'Response.Write "<html><body bgcolor='gainsboro' text='#000000'>已保存为Excel文件.
  
  <a href='" & server.URLEncode(ExcelPath) & "'>下载</a>"
  Else
  Response.Write "在保存过程中有错误!"
  End If
  Set objExcel = Nothing
  objRS.Close
  Set objRS = Nothing
  %>
  
    做人要厚道,请注明转自chinazhan中国站长(www.ChinaZhan.com)。

 
[] [返回上一页] [打 印] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [更多评论...]
中国站长下载
中国站长下载

本页只接受PR>=4 IT类站点连接,申请连接,谢谢您们的支持!希望我们的下载站能够真正帮到中国的站长们!
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图
Copyright © 2005-2006 ChinaZhan.Net. All Rights Reserved .