pb 如何
用FIND 函数实现查 找并转移焦 点在一个数 据窗口中 有若干条数 据,有个s le控件如 何用fin d函数在d atawi ndow中 查找sle 中输入的内 容并将焦点 指向这一行 记录:FI ND() 用法:lo ng ll _find ll_fi nd = dw_2. find( 'yhmc ='+tr im(sl e_1.t ext)+ '',1, dw_2. rowco unt() )//查 找dw_2 中的用户名 称=sle _1文本控 件的值,从 dw_2第 一行到 最 后一行,返 回该行行数 dw_2. scrol ltoRo w(ll_ find) //设置该 行为焦点, 滚动到该行小编还为您整理了以下内容,可能对您也有帮助:
pb如何用FIND函数实现查找并转移焦点?
FIND() 用法:
long ll_find
ll_find = dw_2.find("yhmc="+trim(sle_1.text)+"",1,dw_2.rowcount() )
//查找dw_2中的用户名称=sle_1文本控件的值,从dw_2第一行到 最后一行,返回该行行数。
dw_2.scrolltoRow(ll_find)//设置该行为焦点,滚动到该行。
一般情况下,我们要逐条查找数据窗口中满足某一条件的记录进行处理的时候,我们的代码经常会是下面这种:
ll_findrow=dw.find(findclause,1,dw.rowcount())
do while ll_find>0
<....>
ll_findrow=dw.find(findclause,ll_findrow+1,dw.rowcount())
loop
这种写法最大的陷阱在于,PB的FIND函数在查找的时候,当参数中起始行大于终止行的时候,会从下往上进行查找,而对参数中的起始行和终止行是否有效行不作*。
因此,一旦数据窗口中最后一条记录满足条件时,当处理完最后一条记录后,再去执行FIND的时候,由于ll_findrow+1已经大于dw_rowcount(),PB将会从ll_findrow+1行到dw.rowcount()行开始反向查找满足条件的记录,此时函数仍将返回数据窗口的最后一行,结果就导致程序进行死循环。
所以,为避免出现死循环,一般应在循环的FIND语句前判断ll_findrow是否已超出数据窗口的记录条数,超出则跳出循环。
不过,还有一种更简单的避免死循环的代码写法如下:
ll_findrow=dw.find(findclause,1,dw.rowcount())
do while ll_find>0 <....> ll_findrow=dw.find(findclause,ll_findrow+1,dw.rowcount() +1 )
loop
另外:
用法Find()函数在进行查找时区分大小写因此当应用程序在某列中查找某个值
时大小写匹配的行才是找到的行。
当应用程序使用循环方式查找满足条件的所有行时要注意不要形成死循环下面是。
段循环查找满足指定条件行的一个示例。
long ll_find = 1, ll_end
ll_end = dw_main.RowCount()
ll_find = dw_main.Find(searchstr, ll_find, ll_end)
DO WHILE ll_find > 0
... // 处理找到的行
ll_find++
// 防止死循环
IF ll_find > ll_end THEN EXIT
ll_find = dw_main.Find(searchstr, ll_find, ll_end)
LOOP
pb如何用FIND函数实现查找并转移焦点?
FIND() 用法:
long ll_find
ll_find = dw_2.find("yhmc="+trim(sle_1.text)+"",1,dw_2.rowcount() )
//查找dw_2中的用户名称=sle_1文本控件的值,从dw_2第一行到 最后一行,返回该行行数。
dw_2.scrolltoRow(ll_find)//设置该行为焦点,滚动到该行。
一般情况下,我们要逐条查找数据窗口中满足某一条件的记录进行处理的时候,我们的代码经常会是下面这种:
ll_findrow=dw.find(findclause,1,dw.rowcount())
do while ll_find>0
<....>
ll_findrow=dw.find(findclause,ll_findrow+1,dw.rowcount())
loop
这种写法最大的陷阱在于,PB的FIND函数在查找的时候,当参数中起始行大于终止行的时候,会从下往上进行查找,而对参数中的起始行和终止行是否有效行不作*。
因此,一旦数据窗口中最后一条记录满足条件时,当处理完最后一条记录后,再去执行FIND的时候,由于ll_findrow+1已经大于dw_rowcount(),PB将会从ll_findrow+1行到dw.rowcount()行开始反向查找满足条件的记录,此时函数仍将返回数据窗口的最后一行,结果就导致程序进行死循环。
所以,为避免出现死循环,一般应在循环的FIND语句前判断ll_findrow是否已超出数据窗口的记录条数,超出则跳出循环。
不过,还有一种更简单的避免死循环的代码写法如下:
ll_findrow=dw.find(findclause,1,dw.rowcount())
do while ll_find>0 <....> ll_findrow=dw.find(findclause,ll_findrow+1,dw.rowcount() +1 )
loop
另外:
用法Find()函数在进行查找时区分大小写因此当应用程序在某列中查找某个值
时大小写匹配的行才是找到的行。
当应用程序使用循环方式查找满足条件的所有行时要注意不要形成死循环下面是。
段循环查找满足指定条件行的一个示例。
long ll_find = 1, ll_end
ll_end = dw_main.RowCount()
ll_find = dw_main.Find(searchstr, ll_find, ll_end)
DO WHILE ll_find > 0
... // 处理找到的行
ll_find++
// 防止死循环
IF ll_find > ll_end THEN EXIT
ll_find = dw_main.Find(searchstr, ll_find, ll_end)
LOOP