PB编程技巧二则

发表于:2007-06-11来源:作者:点击数: 标签:
在PB编程中,我们经常需要应用一些小的技巧,如:使数据窗口每页打印固定行、在系统中嵌入Excel对象等。下面,笔者将结合实际介绍这些小的技巧应用。 一、页面的精确打印 关于数据窗口每页打印固定行的问题: 1.增加一个计算列,此计算列必须放在Detail段的Ex

在PB编程中,我们经常需要应用一些小的技巧,如:使数据窗口每页打印固定行、在系统中嵌入Excel对象等。下面,笔者将结合实际介绍这些小的技巧应用。

一、页面的精确打印

关于数据窗口每页打印固定行的问题:

1.增加一个计算列,此计算列必须放在Detail段的Expression中输入:

ceiling(getrow()/20)

//这里20还可以用全局函数取代,这样可以允许用户任意设置每页打印多少行。

2.定义分组,选择选单“Rows->Create Group...”,并按计算列字段分组。最后一定将“check box-->New Page On Group Break”选中。

3.将此计算列设为不可视。

另外,如果需要最后一页不足补空行。也很简单,程序如下:

long ll_pagerow = 10

//每页打印行数

long ll_count, ll_row

ll_count = dw_report.retrieve(...) //取得现有报表的总行数

ll_count = ll_pagerow - mod(ll_count, ll_pagerow)

If ll_count < ll_pagerow then

for ll_row ="" 1 to ll_count

dw_print.insertrow(0)

//补足空行

next

end if

二、如何嵌入Excel对象

在进行程序开发时,有时会需要将PowerBuilder与Excel应用程序结合使用,如将数据检索出来后,按照格式要求,将数据转入到Excel表格中。实现步骤如下:

1.创建并连接对象:

oleobject loo_excel

oleobject loo_sheet

loo_excel=create oleobject

loo_excel.ConnectToNewObject("Excel.Application")

//设置缺省的字体与大小

loo_excel.Application.StandardFont = "Arial Narrow"

loo_excel.Application.StandardFontSize = "8"

loo_excel.Application.Workbooks.Add()

loo_sheet=loo_excel.Application.Workbooks(1).worksheets(1)

loo_excel.Application.Visible=true

loo_excel.Application.ScreenUpdating = false //屏蔽可见属性

2.调用Excel本身的属性,函数,通过数据窗口填写数据到Excel:

loo_excel.Application.ScreenUpdating = true //设置可见属性

3.断开连接并释放对象:

loo_excel.DisconnectObject()

//注:建议引用API函数,捕获Handle。

destroy loo_excel

以上程序已在PB6.0、Windows 98平台上运行通过。



原文转自:http://www.ltesting.net

...