动态设置交叉报表
时 间:2012-09-17 17:24:36
作 者:薛武元 ID:240 城市:常州
摘 要: 最近为交叉报表的问题苦恼,记得以前有人发过一个动态设置的,找不到了,思路是设置足够多的字段,然后用代码设置标签和字段数据源,然后隐藏不需要显示的。
我按此思路做了个例子,不知道有没有更好的办法~ 如果有的话,欢迎跟帖!~
正 文:
最近为交叉报表的问题苦恼,记得以前有人发过一个动态设置的,找不到了,思路是设置足够多的字段,然后用代码设置标签和字段数据源,然后隐藏不需要显示的。
我按此思路做了个例子,不知道有没有更好的办法~ 如果有的话,欢迎跟帖!~
主要代码如下:
Private Sub Command0_Click()
On Error GoTo Err_Command0_Click
Dim FieldCount As Integer '字段数
FieldCount = CurrentDb.QueryDefs("score_交叉查询").Fields.Count
Dim stDocName As String '报表名称
Dim Lb As Label
Dim txt As TextBox
stDocName = "score_交叉报表"
DoCmd.OpenReport stDocName, acViewDesign
'-------------------------------------------------------------------------------------------------------------------------------------
'设置报表标签和数据源
Dim i As Integer
For i = 1 To FieldCount - 1
Reports("SCORE_交叉报表").Controls("Label" & i).Caption = CurrentDb.QueryDefs("score_交叉查询").Fields(i).Name '设置标签
Reports("SCORE_交叉报表").Controls("TXT" & i).ControlSource = CurrentDb.QueryDefs("score_交叉查询").Fields(i).Name '更改数据源
Next
'-------------------------------------------------------------------------------------------------------------------------------------
'将没有用到的控件隐藏
Dim n As Integer
Dim INTcount As Integer
INTcount = 9 - FieldCount '9是此报表预先准备的字段数量
For n = 1 To 9
If n < FieldCount Then
Reports("SCORE_交叉报表").Controls("Label" & n).Visible = True
Reports("SCORE_交叉报表").Controls("txt" & n).Visible = True
Else
Reports("SCORE_交叉报表").Controls("Label" & n).Visible = False
Reports("SCORE_交叉报表").Controls("txt" & n).Visible = False
End If
Next
'-----------------------------------------------------------------------------------------------------
DoCmd.Close acReport, "score_交叉报表", acSaveYes
DoCmd.OpenReport "score_交叉报表", acViewPreview
Exit_Command0_Click:
Exit Sub
Err_Command0_Click:
MsgBox Err.Description
Resume Exit_Command0_Click
End Sub
附件点击下载此
Access软件网QQ交流群 (群号:54525238) Access源码网店
常见问答:
技术分类:
源码示例
- 【源码QQ群号19834647...(12.17)
- 按回车键后光标移动到下一条记录...(02.12)
- 【Access Dsum示例】...(02.07)
- Access对子窗体的数据进行...(02.05)
- 【Access高效办公】上月累...(01.09)
- 【Access高效办公】上月累...(01.06)
- Inputbox输入密码打开查...(12.23)
- 【Access Dsum示例】...(12.16)
- Inputbox输入密码打开窗...(12.13)
- 【Access DCount示...(12.02)

学习心得
最新文章
- 用Access查询语句如何得到前3...(02.17)
- Access快速开发平台--导入导...(02.14)
- 按回车键后光标移动到下一条记录的V...(02.12)
- Access快速开发平台--要实现...(02.10)
- Access快速开发平台--让Pe...(02.08)
- 【Access Dsum示例】用D...(02.07)
- Access对子窗体的数据进行平均...(02.05)
- Access快速开发平台附件上传,...(01.18)
- 【IIF函数示例】用iif函数判断...(01.18)
- Access快速开发平台--如何获...(01.17)