更改报告中的打印机设置

时间:2019-03-26 10:22:03

标签: ms-access access-vba ms-access-2010

当我更新Access应用程序时,我需要在每台PC上更改打印机设置-使用每台打印机上的特定预定义标签来匹配附加的labelprinters名称,然后调整边距。
我想自动化该过程。但是我在获取报告以保存设置时遇到问题。

这个想法是将打印机设置导出到一个表(完成),更新应用程序,然后读取每个报告的“旧”设置,并将其保存为更新的一部分。

问题是,我无法使用Access 2010保存设置。

有什么想法吗?

Dim rpt As Access.Report
Dim rstUpdRptSettings As ADODB.Recordset
Dim NameOfPrinter As String

Set rstUpdRptSettings = New ADODB.Recordset

rstUpdRptSettings.Open "Select * From tblUpdRptSettings", CurrentProject.Connection, adOpenKeyset, adLockOptimistic

Do While Not rstUpdRptSettings.EOF
    DoCmd.OpenReport ReportName:=rstUpdRptSettings!ReportName, View:=acViewDesign, WindowMode:=acHidden
    Set rpt = Reports(rstUpdRptSettings!ReportName)
    NameOfPrinter = rstUpdRptSettings!PrinterName

    With rpt
        .Printer = Application.Printers(NameOfPrinter)
        .Printer.TopMargin = rstUpdRptSettings!TopMargin
        .Printer.BottomMargin = rstUpdRptSettings!BottomMargin
        .Printer.LeftMargin = rstUpdRptSettings!LeftMargin
        .Printer.RightMargin = rstUpdRptSettings!RightMargin
        .Printer.PaperSize = rstUpdRptSettings!PaperSize
    End With
    DoCmd.Close acReport, rpt.Name, acSaveYes
    rstUpdRptSettings.MoveNext
Loop

运行代码不会更改任何设置-也不更改打印机名称,边距或PaperSize。

1 个答案:

答案 0 :(得分:0)

感谢您的评论。

我现在通过将其添加到代码中解决了该问题:

If .DefaultView = 0 Then
    .DefaultView = 1
Else
    .DefaultView = 0
End If
'Set it back
If .DefaultView = 0 Then
    .DefaultView = 1
Else
    .DefaultView = 0
End If

我在这里找到了解释和代码(感谢Daniel): https://social.msdn.microsoft.com/Forums/sqlserver/en-US/8061fb4a-2e5f-4abe-a1ab-493c3d733e82/set-report-margins-using-vba?forum=accessdev

回答者: Daniel Pineault,2010-2016年微软MVP 专业支持:http://www.cardaconsultants.com MS Access提示和代码示例:http://www.devhut.net