asp导出数据库表为excel
网上答案很多的啦,基本都是那两种方法,现在贴出其中一种asp导出数据库为excel的详细代码以作备忘(里面整合了一些其他多余的部分,懒得精简了)。这个导出页面其实没必要显示内容,直接后台调用就行啦!另外一种方法好像是直接写txt文件不过后缀名是.xls而已,有人说后面这种方法效率高,但是实际我在测试的时候发现,可能会导出后导致文本显示不正常,比如18位的身份证如果是全数字的话,asp导出的excel表里的内容就变成3.12105E+17类似的形式,目前还没有找到解决方法,所以最后还是选择了下面这种导出方式,只不过里面的一些东西需要预先设定,肯定可以做成全自动导表的,时间有限还是先将就用着吧!
<%
set conn=server.createobject("adodb.connection")
conn.open "driver={microsoft access driver (*.mdb)};dbq="&server.mappath("test.mdb")
%>
<%
year1=year(now()) '时间
mouth1=month(now())
d1=day(now())
T1=hour(now())
m1=minute(now())
s1=second(now())
'timenow=year1&"年"&mouth1&"月"&d1&"日"&t1&"时"&m1&"分"&s1&"秒"
timenow=year1&"年"&mouth1&"月"&d1&"日"&t1&"时"&m1&"分"&s1&"秒"
dim filename,fs,fn,table,time
table="lingjiang"
time=timenow
fn=table&"_"&time&"_back_up.xls"
Set fs = server.CreateObject("scripting.filesystemobject")
'filename = Server.MapPath("back_up.xls")
filename = Server.MapPath("./"&fn)
'--如果原来的EXCEL文件存在的话删除它
if fs.FileExists(filename) then
fs.DeleteFile(filename)
end if
set rs=server.createobject("adodb.recordset")
sql="select * from sutdent"
'要导出的是test.mdb数据库中的student表
rs.open sql,conn,1,1
Set ExcelApp =CreateObject("Excel.Application")
ExcelApp.Application.Visible = True
Set ExcelBook = ExcelApp.Workbooks.Add
ExcelBook.WorkSheets(1).cells(1,1).value ="student表"
ExcelBook.WorkSheets(1).cells(2,1).value ="序列号"
ExcelBook.WorkSheets(1).cells(2,2).value = "姓名"
ExcelBook.WorkSheets(1).cells(2,3).value = "身份证"
ExcelBook.WorkSheets(1).cells(2,4).value = "学生卡号卡"
ExcelBook.WorkSheets(1).cells(2,5).value = "状态"
ExcelBook.WorkSheets(1).cells(2,6).value = "时间"
ExcelBook.WorkSheets(1).cells(2,7).value = "手机号"
cnt =3
do while not rs.eof
ExcelBook.WorkSheets(1).cells(cnt,1).value = rs("iden")
ExcelBook.WorkSheets(1).cells(cnt,2).value = rs("name")
ExcelBook.WorkSheets(1).cells(cnt,3).value = rs("id_card")
ExcelBook.WorkSheets(1).cells(cnt,4).value = rs("studentno")
ExcelBook.WorkSheets(1).cells(cnt,5).value = rs("state")
ExcelBook.WorkSheets(1).cells(cnt,6).value = rs("dtime")
ExcelBook.WorkSheets(1).cells(cnt,7).value = rs("phone")
rs.movenext
cnt = cint(cnt) + 1
loop
rs.close
set rs=nothing
Excelbook.SaveAs filename '这个是数据导出完毕以后存在filename处的
ExcelApp.Application.Quit '导出以后退出Excel
Set ExcelApp = Nothing '注销Excel对象
response.write "<center>已导出为:"&filename &"<br></center>"
Response.Write "<BR><BR><center><b>导出成功,请选择继续操作</b></center>"
response.Write "<table width=90% cellspacing=1 cellpadding=3 align=center>"
Response.Write "<tr align=center> <td>"
response.write ("<font color=green>√</font><a href='"&fn&"'>下载</a>") & " <font color=green>√</font><a href=javascript:window.close()>关闭</a>"
Response.Write "</td></tr></table>"
%>
基于互联网精神,在注明出处的前提下本站文章可自由转载!
本文链接:https://ranjuan.cn/asp导出数据库表为excel/
赞赏
微信赞赏
支付宝赞赏
发表评论