VB中用DataReport做报表的几个问题,我的分全给他 50

请问高手以下几个问题如何解决呢:一,如何将DataReport.label1.caption=MainFrm.text1.text二,如何将datareport的Sect... 请问高手以下几个问题如何解决呢:
一,如何将 DataReport.label1.caption=MainFrm.text1.text
二,如何将 datareport的Section1,也就是记录显示MainFrm.DataGrid1里的记录
问题一这样解决不行哦,老兄还有别的什么办法吗,还有要求能跟着文本框的内容变
展开
 我来答
创作者zUzVB1Sl31
2012-08-18 · 编程类资料、英语学习资料
创作者zUzVB1Sl31
采纳数:1331 获赞数:5975

向TA提问 私信TA
展开全部

不是这么蛮干的,

1.你要插入一个DataEnvironment,在菜单[工程]里直接添加

右键再点他添加一个Command命令,给Connection和Command随便设置属性,随便设置就好了,不要让他空连接,我是教你用ADO来控制。

设置完了过后,你要添加一个DataReport

DataReport里面有Label也有Text,你拖放在报表上,在他属性里直接添写数据源和命令名称,把报表先设计好,是打印数据连接控件里的数据,不是打印DataGrid,打印DataGrid有专业的工具,如现在的VSPrint。从出发点来讲DataReport是自己画报表,给文本数据源遍历数据库。DataEnvironment数据源是不怎么好控制的,他太老了,所以我教你直接把ADO控件的数据源给他。

在窗体上事件过程中一句话就搞定了:

Set DataEnvironment1.rsCommand1.DataSource = Adodc1

要打印预览就写语句:

 DataReport1.Show

在窗体中拖入一个ADO控件,完整代码如下(以一个按钮事件为例):

Private Sub 按钮名_Click()

Adodc1.ConnctionString="Driver={SQL Server};Server=服务器IP;UID=用户名;pwd=密码;DataBase=数据库名"

Adodc1.RecordSource="Select * From 表 Where 字段='"+窗体上控件名+"'"

Adodc1.Refresh

Set DataEnvironment1.rsCommand1.DataSource = Adodc1

DataReport1.Show

End Sub

整个代码过程就这么简单,报表版式你要自己设置,报表页边距,本身宽度都要设置好,他是默认默认打印机。

如果是要打印DataGrid数据表,那简单,用个VSPrint控件解决,代码加入:

VSPrinter1.StartDoc

VSPrinter1.Zoom = 100 

VSPrinter1.RenderControl = Form1.DataGrid1.hWnd

VSPrinter1.EndDoc

打印出来的是DataGrid数据加上框架,很丑的

jizhongbo
2006-05-20 · TA获得超过2154个赞
知道大有可为答主
回答量:1493
采纳率:0%
帮助的人:890万
展开全部
1、问题一:

Private Sub DataReport_Initialize()
DataReport.label1.caption=MainFrm.text1.text
End Sub

2、问题二:
你要是动态显示MainFrm.DataGrid1里的记录的话,基本上没有什么好的解决办法,因为你需要动态的增加datareport里的元素,但这样又不好控制报表的页面布局格式。所以,还是建议你换个报表控件吧,别再用VB自带的东西了,只适合初级编程时玩玩而已,实际应用的话,那不出手的。
推荐给你一个吧,用VSFLEX和VSPRINT这两个组合比较不错,你到网上搜一下吧,我一直没用这个了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式