Access交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • Access导入导出Wor..

最新文章

  • Access导入导出Wor..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > OFFICE集成/导入导出/交互 > Word导入导出/交互
Word导入导出/交互

Access导入导出Word 题库

如何做一个题库软件,比如计算等级模拟考试软件,机动车科目一考试。这些软件都需要有题库。那么怎么从word中录入这些题库呢?

有如何把Access里面的题目导出到word 方便阅读呢?

如下示例,可以快读导入题库,导出试题。
access数据库 


access数据库 


access数据库 


access数据库 


详细源码:

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

发布人:老汉  
分享到:
点击次数:  更新时间:2017-08-23 17:16:00  【打印此页】  【关闭】
上一条:Access添加图片删除图片和更改图片  下一条:Access 2010创建、管理自定义功能区



相关文章

热门文章

  • [2017-08-23] Access导入导出Word 题库access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2023  www.metinfo.cn