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数据库密码
  • Access键盘快捷键大全..
  • Access安全性之QA详..
  • 攻防实战:注水漏洞的利用和..
  • ACCESS默认保存路径的..

最新文章

  • Access工程名称与文件..
  • Access 实现前后台数..
  • 用SSMA升迁工具移植Ac..
  • 导出Access图片控件的..
  • 同一字段中简单代替 Or ..
  • Access提示“操作或事..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > ACCESS数据库
ACCESS数据库

Access2003中自动完成报表的页面设置

正 文:

access 2003中自动完成报表的页面设置

    使用过Access 2003报表的用户会发现一个问题,报表的页边距在设计时往往事先已经设计好,预览打印都很正常,但当下次再预览或打印时就会发现报表的页边距不正常了,这主要是由于在access2003中页面设置在设计时的参数不能很好的保留,造成了今后使用报表时出现页边距不理想的状况,能否利用VBA程序的方法让报表的页边距自动控制,而无需人工来再次进行页面的设置。

    这里给出一个过程,利用这个过程,在打印报表时会自动按照定义的页面参数进行页面的自动设置。

    将下面的过程放在模块中,使用时只需调用这个过程即可进行报表页面的自动设置。

调用方法:

Setprint(报表名称,方向,上边距,下边距,左边距,右边距)。

'例:设置纵向打印 Setprint("销售报表", 1, 20, 10, 20, 10)
'例:设置横向打印 Setprint("销售报表", 0, 20, 10, 20, 10) 

Option Compare Database
Type str_PRTMIP
    strRGB As String * 28
End Type
Type type_PRTMIP
    xLeftMargin As Long
    yTopMargin As Long
    xRightMargin As Long
    yBotMargin As Long
    fDataOnly As Long
    xWidth As Long
    yHeight As Long
    fDefaultSize As Long
    cxColumns As Long
    yColumnSpacing As Long
    xRowSpacing As Long
    rItemLayout As Long
    fFastPrint As Long
    fDatasheet As Long
End Type

Type str_DEVMODE
    RGB As String * 94
End Type

Type type_DEVMODE
    strDeviceName As String * 16
    intSpecVersion As Integer
    intDriverVersion As Integer
    intSize As Integer
    intDriverExtra As Integer
    lngFields As Long
    intOrientation As Integer
    intPaperSize As Integer
    intPaperLength As Integer
    intPaperWidth As Integer
    intScale As Integer
    intCopies As Integer
    intDefaultSource As Integer
    intPrintQuality As Integer
    intColor As Integer
    intDuplex As Integer
    intResolution As Integer
    intTTOption As Integer
    intCollate As Integer
    strFormName As String * 16
    lngPad As Long
    lngBits As Long
    lngPW As Long
    lngPH As Long
    lngDFI As Long
    lngDFr As Long
End Type


'以下过程用来进行报表页面自动设置,过程所带参数为(报表名称,方向,上边距,下边距,左边距,右边距)。
'例:设置纵向打印 Setprint("销售报表", 1, 20, 10, 20, 10)
'例:设置横向打印 Setprint("销售报表", 0, 20, 10, 20, 10)
Sub Setprint(strName, fx, sbj, xbj, zbj, ybj)
    Const DM_PORTRAIT = 1
    Const DM_LANDSCAPE = 2
    Dim DevString As str_DEVMODE
    Dim dm As type_DEVMODE
    Dim PrtMipString As str_PRTMIP
    Dim PM As type_PRTMIP
    Dim strDevModeExtra As String
    Dim rpt As Report
    ' Opens report in Design view.
    DoCmd.OpenReport strName, acDesign
    Set rpt = Reports(strName)
    PrtMipString.strRGB = rpt.PrtMip
    LSet PM = PrtMipString
    PM.yTopMargin = sbj * 1440 * 0.0394    ' 设置上边距。
    PM.yBotMargin = xbj * 1440 * 0.0394    ' 设置下边距。
    PM.xLeftMargin = zbj * 1440 * 0.0394   ' 设置左边距。
    PM.xRightMargin = ybj * 1440 * 0.0394  ' 设置右边距。
    LSet PrtMipString = PM            ' 更新属性。
    rpt.PrtMip = PrtMipString.strRGB
    If Not IsNull(rpt.PrtDevMode) Then
        strDevModeExtra = rpt.PrtDevMode
        DevString.RGB = strDevModeExtra
        LSet dm = DevString
        dm.lngFields = dm.lngFields or _
             dm.intOrientation    ' Initialize fields.
        If fx = 1 Then
         dm.intOrientation = DM_PORTRAIT '设置纵向打印
        Else
         dm.intOrientation = DM_LANDSCAPE '设置横向打印
        End If
        LSet DevString = dm            ' Update property.
        Mid(strDevModeExtra, 1, 94) = DevString.RGB
        rpt.PrtDevMode = strDevModeExtra
    End If
    DoCmd.Save acReport, strName
    Set rpt = Nothing
    On Error GoTo err1
     DoCmd.OpenReport strName, acViewPreview
err1:
End Sub

发布人:wqm099-网络  
分享到:
点击次数:  更新时间:2009-09-25 08:25:34  【打印此页】  【关闭】
上一条:逐步讲解向Access数据库上传且显示图片  下一条:Access2007循序渐进教程课件与源文件(PPT格式)[8]



相关文章

  • • Access工程名称与文件名称的区别
  • • Access 实现前后台数据库压缩
  • • 用SSMA升迁工具移植Acceses到SQL Server的几点问题
  • • 导出Access图片控件的图片到文件
  • • 同一字段中简单代替 Or 和 in 的多条件查询
  • • Access提示“操作或事件已被禁用模式阻止“解决办法
  • • 如何判断Access数据库是运行在正常完整版本(Full Access)还是运行时版本(Access Runtime)
  • • Access VBA获取U盘(优盘)机器码系列号及U盘开发的各种代码

热门文章

  • [2004-11-05] 谁可以告诉我怎样将ACCESS中的窗体保存为网页形式access数据库
  • [2015-01-13] 解决同时装Office 2003、2007和2010 版本切换总发生重新配置的办法access数据库
  • [2009-11-03] 以前流行的4种Access数据库安全方式access数据库
  • [2009-04-24] 用代码通过ODBC刷新链接(mdb+SQL SEVER2000)access数据库
  • [2004-10-19] 怎么让多个人同时打开Access数据库?access数据库
  • [2008-10-13] 用代码打开Access文件的两种方法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