问题描述
我试图在不打开报告的情况下从表单打印批次 ID 数据表。 使用下面的代码,我可以打开只显示我想要的数据的报告
Private Sub PrntbLblV1_Click()
Dim str As String
str = "[BatchID] = " & Me.BatchID
DoCmd.OpenReport "RprtLblPrint",acViewPreview,str
DoEvents
End Sub
这会在打印预览中打开我想要的记录...但是我只想将记录发送到打印机...我已经尝试过
DoCmd.OpenReport "RprtLblPrint",acnormal,str
DoCmd.runcommand acCmdPrint
DoEvents
但它打印每个批处理事务而不仅仅是当前的...我认为问题是我在报告属性中有一个进一步的过滤器,可以过滤加载以删除已完成的事务 [Complete] = False 这是一个真/假复选框.. 我似乎无法将已完成的和批处理标准嵌套到 DoCmd.OpenReport 的 where 部分中 它不断抛出类型不匹配错误
str = "[BatchID] = " & Me.BatchID And [Complete] = False
我试过把它分开
Dim str As String
Dim Cmplt As String
str = "[BatchID] = " & Me.BatchID
Cmplt = [Complete] = False
DoCmd.OpenReport "RprtLblPrint",str And Cmplt
DoCmd.runcommand acCmdPrint
关于如何将 2 个过滤条件加入 DoCmd.OpenReport where 条件有什么建议吗??
解决方法
它需要是过滤器字符串的一部分,如:
str = "[BatchID] = " & Me.BatchID & " And [Complete] = False"