搜索 | 会员  
数据库数据生成word文档的方法
来源: 本站原创   作者:佚名  日期:2004/8/12  类别:数据库  主题:MS-SQL  编辑:dezai
我这例子是生成教师个人资料的word文档。============================='这里写你的数据库连接Response.Buffer = True
我这例子是生成教师个人资料的word文档。
=============================

'这里写你的数据库连接
Response.Buffer = True '这个好像得留着

PeopleId=request("PeopleId")
Set rs = Server.CreateObject("ADODB.Recordset")
sql="select * from People where PeopleId=" & PeopleId
rs.open sql,conn,3,3
if rs.eof and rs.bof then
做点事情
end if
===========================================
上面是把教师的资料取出来,换成你的东西。
下面生成文件。
===============================

Dim fso, MyFile
Set fso = CreateObject("Scripting.FileSystemObject") '用到fso
sFileName = "temp.doc"
Set MyFile = fso.CreateTextFile(Server.MapPath(".") & "\word\"&sFileName, True) '文件放在当前目录的word/下
myString="这里是你预先排好的word文档,要填的地方都空好了,怎么弄底下告诉!"
MyFile.WriteLine(myString)
MyFile.Close '关闭文件
===================================
文件已经生成了。注意在iis里把word目录设置为“写入”。
以下将word文档以数据流写出,不让IE自动打开,防止出错误提示。
==================================

Dim strFilePath
Const adTypeBinary = 1

strFilePath = "word/temp.doc"

Set objStream = Server.CreateObject("ADODB.Stream")
objStream.Open
objStream.Type = adTypeBinary
objStream.LoadFromFile Server.MapPath(strFilePath) 'change the path if necessary

Response.ContentType = "application/octet-stream"

Response.AddHeader "Content-Disposition", "attachment; filename=化工学院教职工数据采集表--"&rs("name")&".doc"
'如果文件名固定,那就直接filename=文件名.doc,这个名字就是用户选“保存”时,出现的名字
Response.BinaryWrite objStream.Read
Response.Flush

objStream.Close
Set objStream = Nothing '写完,释放对象
===============================
上面是让word文档以附件的形式打开,当然没错误了。
发现把attachment去掉,就会用ie直接打开了。不让它直接打!
=======================

rs.close
set rs=nothing
conn.close
set conn=nothing
====================
关闭释放数据库连接。
=================================
注:myString="" 里面到底是什么?
用word做一个你要的格式的文档,都排好了,
把要填的地方做好标记,比如写几个字什么的。
然后“另存为”web页面。本文所说的是文档里没有图片的情况,有的话我也不会。

到你的硬盘里找到这个web页面,打开,查看源文件,ctrl+a,ctrl+c,
在word里,ctrl+N,ctrl+v,ctrl+F,点“替换”标签,
第一步:查找内容填双引号",替换为填两个双引号"",全部替换即可。
第二步:点“高级”,查找内容里填“特殊字符”的“段落标记”,替换为填“特殊字符”的“不间断空格”,全部替换即可。
然后ctrl+a,ctrl+c,把东西paste在myString=""的两个引号之间。
==========================================
这时.asp文件已经可以执行,不过生成的是空word文档,啥也没填,没用。
在myString后面的引号里,找你那些标记,比如姓名一栏你填的是“西瓜”,
那么现在找到“西瓜”两个字,删除,打"&rs("name")&"
包括前后两个引号。以此类推,把所有的地方都用库中的纪录搞定。
========================================
哦,现在就行了。基本满足要求了。
注:几个小问题

1。有时保存你的word文档到web页面时,会生成”你的文件名.files"的文件夹。
那你用这个.asp文件动态生成word文档时,会提示“XXXX丢失”,不爽!
解决办法:在你保存的web页面,查看源文件,查找“你的文件名.files“,
相关的地方都删除掉。一般会有还有style里的。看着删吧。

2。这个.asp文件执行是会出现下载提示框,如果选“打开”的话,
word就会打开生成的这个文档,我发现有时是以“web视图”打开的,
有时是“页面视图”打开的。很是奇怪,仔细对比了一下,发现:
只要在你的myString里找,在后面加上Print,那么就会以“页面视图”打开了。好!
德仔网尊重行业规范,每篇文章都注明有明确的作者和来源;德仔网的原创文章,请转载时务必注明文章作者和来源:德仔网;
头条那些事
大家在关注
广告那些事
我们的推荐
也许感兴趣的
干货