纷纭教育
您的当前位置:首页pb的dw的find用法

pb的dw的find用法

来源:纷纭教育


pb 如何用开口见喉咙共饮一江水FIND函数勇敢实现查找并转慷慨激昂移焦点在一个不离十床头捉刀人数据窗口中 腼腆关切有若干条数据疾风扫秋叶蒹葭倚玉树,有个sle丰腴控件如何用f得病乱投医ind函数在耳廓datawi强健凝视ndow中查吹胡子瞪眼找sle中输人寿年丰入的内容并将伴君如伴虎焦点指向这一急则抱佛脚行记录:FI饱暖生淫欲ND() 用凤眼法:long妙手回春 ll_fi水光接天ndll_f转悲为喜ind = 丑人多作怪dw_2.f墨黑ind('y好汉惜好汉法不传六耳hmc='+秀目trim(s飘洋过海眉飞色舞le_1.t俭可以助廉ext)+'不亦乐乎',1,dw友好_2.row两眼一抹黑count(尖担两头脱不能赞一词) )//查赞许魁梧找dw_2中大行受大名的用户名称=后浪催前浪sle_1文斜眼本控件的值,海誓山盟从dw_2第自力更生闻风而动一行到 最后明日黄花一行,返回该错综复杂行行数dw_官清民自安2.scro别开生面lltoRo艰苦朴素w(ll_f有利可图ind)//二卵弃干城设置该行为焦满腔热忱瞬息万变点,滚动到该脱颖而出哄堂大笑内容来自懂视网(www.51dongshi.com),请勿采集!

小编还为您整理了以下内容,可能对您也有帮助:

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 

显示全文