设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

12345下一页
返回列表 发新帖
查看: 19297|回复: 45
打印 上一主题 下一主题

[Access本身] 导入导出Word之实例

[复制链接]
跳转到指定楼层
1#
发表于 2009-7-27 16:50:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 todaynew 于 2009-7-27 17:29 编辑










Private Sub 导入题库_Click()
Dim doc As New Word.Application
Dim myname As String
Dim str As String
Dim i As Long, m As Long
Dim rs As New ADODB.Recordset
Dim sql As String
Dim n As String, p As Boolean, q As Long
On Error GoTo err_错误
sql = "select * from 题库子表"
rs.Open sql, CurrentProject.Connection, adOpenKeyset, adLockOptimistic
myname = GetFolder
doc.Documents.Open FileName:=myname
doc.Visible = True
doc.Activate
doc.Documents(myname).Activate
m = doc.Documents(myname).Paragraphs.Count
For i = 2 To m
    doc.Documents(myname).Paragraphs(i).Range.Select
    str = doc.Selection.Text
    p = InStr(str, "一、判断题") > 0
    p = p Or InStr(str, "二、填空题") > 0
    p = p Or InStr(str, "三、选择题") > 0
    p = p Or InStr(str, "四、简答题") > 0
    If p = True Then
        If InStr(str, "一、判断题") > 0 Then q = 1
        If InStr(str, "二、填空题") > 0 Then q = 2
        If InStr(str, "三、选择题") > 0 Then q = 3
        If InStr(str, "四、简答题") > 0 Then q = 4
    Else
        doc.Selection.Find.Execute FindText:="题目:", Forward:=True
        If doc.Selection.Text = "题目:" Then
            n = "题目:"
            doc.Documents(myname).Paragraphs(i).Range.Select
            rs.AddNew
            rs("题库ID") = 1
            rs("题型ID") = q
            rs("题目") = str
            If InStr(str, "题目:链接:") > 0 Then
            doc.Selection.Copy
            rs("链接") = "请通过复制拷贝方式链接题目!"
            End If
            
            rs.Update
        Else
            doc.Selection.Find.Execute FindText:="答案:", Forward:=True
            If doc.Selection.Text = "答案:" Then
                n = "答案:"
                rs("答案") = str
                rs.Update
            Else
                If n = "题目:" Then
                    rs("题目") = rs("题目") & Chr(10) & str
                    rs.Update
                Else
                    rs("答案") = rs("答案") & Chr(10) & str
                    rs.Update
                End If
            End If
        End If
    End If
Next
Me.题库子窗体.Requery
Me.编辑子窗体.Requery
Set doc = Nothing
rs.Close
Exit_退出:
Exit Sub
err_错误:
    doc.Quit
    MsgBox "出现操作错误,请检查。"
Resume Exit_退出:
End Sub

Private Sub 导出试卷_Click()
Dim myname As String
Dim myfolder As String
Dim x As Boolean
Dim myFSO As New FileSystemObject
Dim doc As New Word.Application
Dim i As Long, j As Long, m As Long
Dim myID As Long
Dim strsql As String
Dim rs1 As New ADODB.Recordset
Dim sql1 As String
Dim rs2 As New ADODB.Recordset
Dim sql2 As String
On Error GoTo err_错误
sql1 = "select * from 题型表"
rs1.Open sql1, CurrentProject.Connection, adOpenKeyset, adLockOptimistic

    '---------------------------------------------------
    '建立或打开WORD文件
    doc.Visible = True
    myname = InputBox("请输入试卷名称:") & ".doc"
    myfolder = CurrentProject.Path & "\试卷\"
    x = myFSO.FileExists(myfolder & myname)
    If Not (x) Then
        doc.Documents.Add
        doc.Activate
        doc.ActiveDocument.SaveAs FileName:=myfolder & myname
    Else
        doc.Documents.Open FileName:=myfolder & myname
        doc.Activate
    End If
   
    '----------------------------------------------------
    '导出ACCESS数据
   
    doc.Selection.WholeStory                             '全选
    doc.Selection.Delete Unit:=wdCharacter, Count:=1     '删除
    doc.Selection.MoveDown Unit:=wdLine, Count:=1, Extend:=wdExtend
    doc.Selection.TypeText Text:="试卷名称:" & myname
    doc.Selection.TypeParagraph
    doc.Selection.TypeParagraph
    '导出题目
    For i = 1 To rs1.RecordCount
        sql2 = "select * from 题库子表 where 选中=yes and 题型ID=" & rs1("题型ID")
        rs2.Open sql2, CurrentProject.Connection, adOpenKeyset, adLockOptimistic
            doc.Selection.TypeText Text:=i & "、" & rs1("题型名称")
            doc.Selection.TypeParagraph
        For j = 1 To rs2.RecordCount
            doc.Selection.TypeText Text:="(" & j & ")"
            If IsNull(rs2("链接")) = True Then
                doc.Selection.TypeText Text:=Mid(rs2("题目"), 4)
            Else
                doc.Selection.Font.Color = wdColorRed
                doc.Selection.TypeText Text:="提示:该题有链接内容,请手工导入。"
                doc.Selection.Font.Color = wdColorAutomatic
            End If
            doc.Selection.TypeParagraph
            rs2.MoveNext
        Next
    rs2.Close
    rs1.MoveNext
    Next
   
    '导出答案
    doc.Selection.TypeParagraph
    doc.Selection.TypeParagraph
    doc.Selection.TypeText Text:="试卷答案:"
    doc.Selection.TypeParagraph
    rs1.MoveFirst
    For i = 1 To rs1.RecordCount
        sql2 = "select * from 题库子表 where 选中=yes and 题型ID=" & rs1("题型ID")
        rs2.Open sql2, CurrentProject.Connection, adOpenKeyset, adLockOptimistic
            doc.Selection.TypeText Text:=i & "、" & rs1("题型名称")
            doc.Selection.TypeParagraph
        For j = 1 To rs2.RecordCount
            doc.Selection.TypeText Text:="(" & j & ")"
            If IsNull(rs2("链接")) = True Then
                doc.Selection.TypeText Text:=Mid(rs2("答案"), 4)
            Else
                doc.Selection.Font.Color = wdColorRed
                doc.Selection.TypeText Text:="提示:该题有链接内容,请手工导入。"
                doc.Selection.Font.Color = wdColorAutomatic
            End If
            doc.Selection.TypeParagraph
            rs2.MoveNext
        Next
    rs2.Close
    rs1.MoveNext
    Next
   
    doc.Selection.Sections(1).Footers(1).PageNumbers.Add PageNumberAlignment:= _
        wdAlignPageNumberCenter, FirstPage:=True           '设置页码
    doc.Documents.Save                                     '保存
'取消题库表选中标识
strsql = "UPDATE 题库子表 SET 题库子表.选中 = no  "
strsql = strsql & "WHERE (((题库子表.选中)=Yes));"
CurrentDb.Execute strsql

Set doc = Nothing
Set myFSO = Nothing
Set myFile = Nothing
Exit_退出:
Exit Sub
err_错误:
    doc.Quit
    MsgBox "出现操作错误,请检查。"
Resume Exit_退出:
End Sub

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

评分

参与人数 4经验 +43 收起 理由
huangyz_xy + 15
+ 10 精品文章
cuxun + 10 不错的示例
5988143 + 8 支持原创作品~真的不错~

查看全部评分

本帖被以下淘专辑推荐:

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享分享 分享淘帖1 订阅订阅
2#
发表于 2009-7-27 17:17:42 | 只看该作者
谢谢分享
3#
发表于 2009-7-27 19:12:53 | 只看该作者
谢谢共享,下载学习。
4#
发表于 2009-7-27 20:00:09 | 只看该作者
支持原创作品~真的不错~
5#
发表于 2009-7-28 10:05:05 | 只看该作者
大哥,我点导入,弹出WORD窗口,导入三、四行就出现“出现操作错误,请检查”!怎么回事啊
还有想请教:有没有将图片导入WORD指定位置的例子,谢谢
6#
 楼主| 发表于 2009-7-28 15:20:09 | 只看该作者
支持原创作品~真的不错~
5988143 发表于 2009-7-27 20:00


谢谢版主支持
7#
 楼主| 发表于 2009-7-28 15:23:49 | 只看该作者
大哥,我点导入,弹出WORD窗口,导入三、四行就出现“出现操作错误,请检查”!怎么回事啊
还有想请教:有没有将图片导入WORD指定位置的例子,谢谢
asklove 发表于 2009-7-28 10:05


我测试时没有出现问题,呵呵。你可以把错误处理的语句都屏蔽掉,然后看看是那句出错了。

导入图片和导入文字应该差不多,似乎只是需要从图片控件读取数据,然后导入到word文档指定位置就可以了,不过具体尚未作过。
8#
发表于 2009-7-28 15:24:41 | 只看该作者
谢谢分享
9#
发表于 2009-7-28 15:57:33 | 只看该作者
谢谢分享
10#
发表于 2009-7-28 16:22:01 | 只看该作者
错误信息:  方法'Find'作用于对象'Selection'时失败
停在:   doc.Selection.Find.Execute FindText:="题目:", Forward:=True
难倒是引用上的问题?好像没有丢失什么的?郁闷
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-11-5 02:17 , Processed in 0.117710 second(s), 38 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表