着急,asp导出为excel,为什么保存了但是没有生成excel文件呢?现在只是在我本机上执行的。谢谢

aduo_0513 2009-05-01 09:33:34
因为一个项目,学习了网上一位前辈的asp导出为excel,为什么最后没有文件呢?着急,在线求助!谢谢!
<%
server.scripttimeout=100000 '处理时间较长,设置值应大一点
On Error Resume Next
set objExcelApp = createObject("Excel.Application")
objExcelApp.DisplayAlerts = false
objExcelApp.Application.Visible = false
Dim straddr
straddr= server.mappath(".")
objExcelApp.WorkBooks.add
set objExcelBook = objExcelApp.ActiveWorkBook
set objExcelSheets = objExcelBook.Worksheets
set objSpreadsheet = objExcelBook.Sheets(1)
Dim Conn
Dim Connstr
Dim DB
DB="people.mdb" '这里选择数据库
Set conn = Server.createObject("ADODB.Connection")
Connstr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" & Server.MapPath(DB)
Conn.Open Connstr
Dim objRS
Set objRS = Server.createObject("ADODB.Recordset")
objRS.Open "select * FROM people",conn,1,3 '这里用sql语句查询需要导出的内容
'response.write("'"&objRS.RecordCount&"'")
If objRS.EOF then
response.write("Error")
respose.end
End if

Dim objField, iCol, iRow
iCol = 1 '取得列号
iRow = 1 '取得行号
objSpreadsheet.Cells(iRow, iCol).Value = "用ASP将Access中的数据导入到Excel文件" '单元格插入数据
'objSpreadsheet.Columns(iCol).ShrinkToFit=true '设定是否自动适应表格单元大小(单元格宽不变)
'设置Excel表里的字体
'objSpreadsheet.Cells(iRow, iCol).Font.Bold = True '单元格字体加粗
'objSpreadsheet.Cells(iRow, iCol).Font.Italic = False '单元格字体倾斜
'objSpreadsheet.Cells(iRow, iCol).Font.Size = 20 '设置单元格字号
'objSpreadsheet.Cells(iRow, iCol).ParagraphFormat.Alignment=1 '设置单元格对齐格式:居中
'objspreadsheet.Cells(iRow,iCol).font.name="宋体" '设置单元格字体
'objspreadsheet.Cells(iRow,iCol).font.ColorIndex=2 '设置单元格文字的颜色,颜色可以查询,2为白色
'objSpreadsheet.Range("A1:F1").merge '合并单元格(单元区域)
'objSpreadsheet.Range("A1:F1").Interior.ColorIndex = 1 '设计单元络背景色
'objSpreadsheet.Range("A2:F2").WrapText=true '设置字符回卷(自动换行)
iRow=iRow+1
For Each objField in objRS.Fields
objSpreadsheet.Columns(iCol).ShrinkToFit=true
objSpreadsheet.Cells(iRow, iCol).Value = objField.Name
'设置Excel表里的字体
objSpreadsheet.Cells(iRow, iCol).Font.Bold = True
objSpreadsheet.Cells(iRow, iCol).Font.Italic = False
objSpreadsheet.Cells(iRow, iCol).Font.Size = 20
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 = 1
For Each objField in objRS.Fields
response.write(objField.Value)
If IsNull(objField.Value) then
objSpreadsheet.Cells(iRow, iCol).Value = ""
Else
objSpreadsheet.Columns(iCol).ShrinkToFit=true
objSpreadsheet.Cells(iRow, iCol).Value = objField.Value
objSpreadsheet.Cells(iRow, iCol).Halignment = 2
objSpreadsheet.Cells(iRow, iCol).Font.Bold = False
objSpreadsheet.Cells(iRow, iCol).Font.Italic = False
objSpreadsheet.Cells(iRow, iCol).Font.Size = 10
'objSpreadsheet.Cells(iRow, iCol).Halignment = 2
objSpreadsheet.Cells(iRow, iCol).ParagraphFormat.Alignment=1
End If
iCol = iCol + 1
Next 'objField
objRS.MoveNext
Loop

Dim SaveName
SaveName="people"
Dim objExcel
Dim ExcelPath
'ExcelPath = "" & SaveName & ".xls"
ExcelPath = "c:\people.xls"
If objExcelBook.SaveAs (server.mappath(ExcelPath)) then
Response.Write "<html><body bgcolor='gainsboro'text='#000000'>已保存为Excel文件. <a href='"&server.URLEncode(ExcelPath) & "'>下载</a>(右键,目标另存为,能保存下来)"
Else
Response.Write "在保存过程中有错误!"
End If
objExcelApp.Quit
set objExcelApp = Nothing

%>


...全文
131 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
aduo_0513 2009-05-06
  • 打赏
  • 举报
回复
o,谢谢,可以啦,我都不知道是什么原因,后来重新弄了下就好了,哎...
robake 2009-05-03
  • 打赏
  • 举报
回复
先看看是什么错误。
redcn2004 2009-05-02
  • 打赏
  • 举报
回复
把 on error resume next 这个代码注释掉,在进行调试

28,390

社区成员

发帖
与我相关
我的任务
社区描述
ASP即Active Server Pages,是Microsoft公司开发的服务器端脚本环境。
社区管理员
  • ASP
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧