标题:求连续数据的筛选思路
只看楼主
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:0 


SET DATE TO YMD
d日期 = DATE()
n年 = YEAR(d日期)
n月 = MONTH(d日期)
c年月 = TRANSFORM(n年)+"/"+PADL(n月,2,"0")+"/"
n月天数 = DAY(GOMONTH(DATE(n年, 1, 31), n月 - 1))
cmd = "CREATE CURSOR tt (姓名 C(8)"
FOR i=1 TO n月天数
    IF !INLIST(DOW(CTOD(c年月+TRANSFORM(i)),2),6,7) &&AND !节假日(i)
        cmd = cmd + ",d"+PADL(i,2,"0")+" I"
    ENDIF
ENDFOR
cmd = cmd + ")"
EXECSCRIPT(cmd)
APPEND FROM 旷工
? "连续旷工3日:"
SCAN
    FOR i=2 TO FCOUNT()-2
        IF EVALUATE(FIELD(i))!=0 AND EVALUATE(FIELD(i+1))!=0 AND EVALUATE(FIELD(i+2))!=0
            ? 姓名, FIELD(i),FIELD(i+1),FIELD(i+2)
        ENDIF
    ENDFOR
ENDSCAN
CLOSE DATABASES ALL  
RETURN
收到的鲜花
  • lljchi2016-12-28 18:36 送鲜花  5朵   附言:结贴早了,评分追加!
  • lljchi2016-12-28 18:36 送鲜花  5朵  
2016-12-28 14:54
lljchi
Rank: 2
等 级:论坛游民
帖 子:172
专家分:95
注 册:2016-7-21
得分:0 
回复 21楼 吹水佬
判断连续时用vfp的自带函数更易看懂了,和sdta版主不同的思路
2016-12-28 17:58
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册:2012-2-5
得分:0 
? "连续旷工3日:"
SCAN
    FOR i=4 TO FCOUNT()
        IF EVALUATE(FIELD(i))!=0 AND EVALUATE(FIELD(i+1))!=0 AND EVALUATE(FIELD(i+2))!=0
            ? 姓名, FIELD(i),FIELD(i+1),FIELD(i+2)
        ENDIF
    ENDFOR
ENDSCAN

吹版的这段代码就可以解决问题

[此贴子已经被作者于2016-12-29 01:37编辑过]


坚守VFP最后的阵地
2016-12-28 23:46



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-472993-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.830009 second(s), 9 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved