请问有没有用于VB数据库表格打印的控件?

sdmyhy 2004-04-29 09:43:42
各位高手,不知道有没有用于VB数据库以及表格(最好是listview)打印的控件和例程??本人想学着写一个小型的数据库程序。
...全文
36 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
hongsongboy 2004-04-30
  • 打赏
  • 举报
回复
打印预览控件(免费)
===============================
http://sky300.com:88/hongsong/ylys.rar
===============================
支持MSHFLEX,MSFLEX控件打印,自定义标题、表头、页头、表尾、输出图像(.BMP .JPG),打印缩放功能,等还有很多功能等待你去开发。

里面有演示代码。
suntt 2004-04-30
  • 打赏
  • 举报
回复
建议采用Excel隐藏导出、打印。操作上也很简单。
给个例子:(我收藏的)

把资料输往Excel来列印

 
●这是一个与VBA无关的技术,但因为这是对Excel来控制,因此收录在Office VBA单元里,并解决一些寄信来问这个问题网友的疑惑。
●这个表单将是等一下要把资料丢给Excel列印的主角,上面有一个Text1,每一栏资料都以 , 逗号来做间格,而每一笔资料间则以vbCrlf来做间隔(按Enter键啦~~),而Command1负责把资料丢给Excel并负责所有动作。


●如果你的电脑有安装Excel,可以在引用项目里找到Excel OLE Object Library,只不过大家的版本会不太一样,小瓜瓜比较穷,所以还在用Excel97。


●开始实作:

(一般)
Dim MyXlsApp As Excel.Application
'设MyXlsApp为Excel的Application物件之表单的全域变数
Private Sub Command1_Click()
Dim RowData As Variant '用来拆解Text1内的每一行资料
Dim ColData As Variant '用来拆解Text1内的每一栏资料
Dim RowTmpDat As Variant 'For each行资料暂存
Dim ColTmpDat As Variant 'For each栏资料暂存
Dim R As Long
Dim C As Long
R与C是用来记录待会在Sheet上移动后的Row与Column位置

Set MyXlsApp = CreateObject("Excel.Application")
'建立Excel.Application物件
MyXlsApp.Visible = True
MyXlsApp.Workbooks.Add
'新增Wookbooks(Sheets与一些其它物件的集合)

RowData = Split(Text1.Text, vbCrLf)
'依跳行字元把Text1.Text拆成一行行的资料
R = 0
For Each RowTmpDat In RowData
'再从被拆成一行行的资料各别把栏位里的资料提出来
ColData = Split(RowTmpDat, ",")
R = R + 1
C = 64
For Each ColTmpDat In ColData
C = C + 1 'Chr(65) = A, Chr(66) = B, Chr(67) = C, ......
MyXlsApp.Range(Chr(C) & R).Select
'移到第C栏第R行
MyXlsApp.ActiveCell.Value = ColTmpDat
'把拆得的每一栏资料填到Excel的Cell里
Next
Next
MyXlsApp.Worksheets.PrintPreview
'启动预览列印
MyXlsApp.DisplayAlerts = False
'不提示储存
MyXlsApp.Quit
'硬是把Excel给关闭
End Sub
●执行 ●把资料一笔一笔(按Enter来区隔)输入,比把每一笔资料一栏一栏的以英文字的逗号来分隔,然后按下Command1。


●喔!资料被一个一个输往相对应的Cell,帅喔!!。


●资料输完后,预览列印就跑出来了,赶快预览看看,并执行列印~赞赞赞~~。


●列印完后,Excel就自动的被关闭了,嗯,太棒了,赶快去试试吧!
●这样的写法有个致命的缺点──它只能输入26栏的资料,当C=65、R=1时,Cell="C1",当C=90、R=1时,Cell="Z1",当C=91、R=1,得到得结果是Cell="[1",Excel没有此一表示法,所以会产生Error,解决法,对C使用Mod并对C以\除法得到的结果放置另一变数,{Cell = Chr(C\26) & Chr(C Mod 26) & R}←这是理论,正确执行码请自己调整。




taomaintao 2004-04-30
  • 打赏
  • 举报
回复
网上有很多控件
flyingZFX 2004-04-30
  • 打赏
  • 举报
回复
菜单下“工程”-->“添加Data report”就行了,不过我建议自己写个导出Excel的程序就更好了。控件用DataGrid和MSHFlexGrid就足够了
cyb1017 2004-04-30
  • 打赏
  • 举报
回复
up
huangjianyou 2004-04-30
  • 打赏
  • 举报
回复
菜单下“工程”-->“添加Data report”就行了,不过我建议自己写个导出Excel的程序就更好了。控件用DataGrid和MSHFlexGrid就足够了。
153608789 2004-04-30
  • 打赏
  • 举报
回复
DataReport在vb6.0中有吗?! 若有:在“部件”那个地址?
dragon525 2004-04-29
  • 打赏
  • 举报
回复
vb自带的DataReport简单易学,足已应付一般的打印要求!
表格控件总览:   在VB开发环境中,表格控件在界面开发元素中占有重要的地位。它不仅有外观整洁、表达形式规范的优点,而且更重要的是它较高的信息表现率(就是相对于其他控件来说能够表达更多的信息),随着信息时代的到来,它的应用将更加的广泛。    那么在VB平台下,如何操作这一功能强大的控件元素呢?事实上我们知道,VB平台下面的表格控件是相当丰富的,总结下来提供了4种类型:Microsoft Data Bound grid Control、Microsoft Datagrid Control、Microsoft Flexgrid Control、Microsoft Hierarchial Flexgrid Control. 这四种表格各有其特点,下面我们一一讨论。   1. Microsoft Data Bound grid Control   此控件主要用于数据绑定(可以不绑定,但是因为不提供对单个cell的控制支持,所以实际上这样做是不经济的)。具体说来,就是数据源比较固定的情况下可以使用这种控件。   具体使用方法是设定此控件的datasource属性,就可以不用编写任何代码就可以显示该数据源所指向的记录数据。比如可以将datasource设置为一个data控件,而data控件又指向数据库"成绩"的 一个"语文"表,那么当程序运行时,它就自动显示此"语文"表的数据。 基本步骤如下: 1、向工程上添加Microsoft Data Bound Grid Control控件,即DBGrid控件。 2、在窗体上添加DBGrid控件DBGrid1和Data控件Data1。 3、设置Data1的DatabaseName属性为你要看的数据库的名字。 4、设置Data1的RecordSource属性为表的名字或合法的SQL Select语句。 5、设置DBGrid1的DataSource属性为Data1。   从上面的分析看得出来,这个控件虽然操作方便,但是它也有局限性,就是不能对显示的数据进行灵活的控制操作,比如有些数据允许用户修改,有些数据却不允许用户修改,而此控件却只能提供全部数据源的原子操作:即要么全部允许修改,要么就全部不允许。还有另外此控件也不提供对单个单元格(cell)进行操作,所以提供不了更为个性化的界面风格。   2. Microsoft Datagrid Control   此控件跟前面介绍的Data Bound grid Control控件很相似,也是主要进行绑定操作,而缺点和Data Bound grid Control完全一样。但是它跟Data Bound grid Control不一样的是其数据源的驱动引擎只能是OLEDB形式的,不能是DAO,比如就可以使用ADO数据控件,不能使用DATA控件。而Data Bound grid Control却刚好和它相反,这一点在开发中一定要注意。   3. Microsoft Flexgrid Control与Microsoft Hierarchial Flexgrid Control.   这里重点介绍这两种控件,因为在实际开发中,这两种控件应用的场合更多一些,它不仅能够反映数据,而且也能把数据的修改信息反映到数据库中去,所以弥补了上述两种控件的不足。   如果数据不需要修改,那么可以进行绑定操作,其方法跟前面介绍的完全一样,就是通过设置DataSource属性来完成数据的显示工作。但是实际开发中,需要对整个表格控件更为灵活的显示控制。   在给出例程之前,有必要对这一控件进行比较详尽的认识:这种控件允许将文本或者图象放置于每个单元格之中,控件的Row与Col属性允许用户在代码中指定当前行和列,当然也可通过操作鼠标和键盘来改变这两个属性,而text属性指明当前单元格的文本。如果单元格的文本太长而不能完全显示出来的话,可以通过将WordWrap属性设置为true来达到显示的目的。下面将比较重要的属性小结如下:   DataSource---------用来指定需要绑定的数据源,比如data控件。   Cellpicture----------用来设定当前单元格的图象,便于显示该图象。此属性不能在设计时使用。   Col,Row---------------设定当前列和当前行,注意它们均是从0开始的,如果同时设定它们,可以指定当前的单元格。设计时也不能使用。   Cols,Rows---------------设置表格控件总的列数和行数。   Hwnd---------------表格句柄,可以结合Windows API对表格控件进行更高级的控制。   Text---------------指定当前的单元格的文本内容。   TextMatrix(i,j)-------此属性比较重要,它用来指定第I行和第j列所确定的单元格的文本内容。它等价于下面的代码: MSHFlexGrid1.Rows =i MSHFlexGrid1.Cols =j MSHFlexGrid1.Text =指定的字符串   WordWrap-------为ture时可以在当前单元格换行显示,否则如果要显示的字符的长度超过列宽,那么就不能显示完全。

1,451

社区成员

发帖
与我相关
我的任务
社区描述
VB 控件
社区管理员
  • 控件
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧