当我更新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。
答案 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