标题:一个循环坎套问题
只看楼主
总是出错
Rank: 2
等 级:论坛游民
威 望:1
帖 子:248
专家分:24
注 册:2012-12-24
结帖率:73.47%
已结贴  问题点数:20 回复次数:7 
一个循环坎套问题
一个循环坎套问题
  
  表A
  三个字段 为A1,A2 A3。A1为日期型,A2,A3为字符型。
  A1 A2均有重复数据,A3是A1的日排序,无重复数据。
  现根据 A1和A2写入A3

  dA1=date() 此日期A表记录无
  
   SELE 表A
   SCAN FOR A2="AAA"
       if dA1=A1
          loop
       else
          dA1=A1
       endif
         n1=1
           scan for A1= dA1 AND A2="AAA"
           cA3=PADL(ALLTRIM(STR(n1,4)),4,"0")
           
              REPLACE A3 WITH cA3
            n1=n1+1
          endscan
      endscan
           
       程序运行后,只写入第一条符合条件的A3.
       也就是说外循环只运行一次。
      
       为找出问题,把程序拆分如下:
      
        dA1=date()  此日期A表记录无
          SELE 表A
           SCAN FOR A2="AAA"
           if dA1=A1
                loop
           else
              dA1=A1
           endif
           ? A1
          endscan
                  运行正常,所有A2="AAA" 的A1记录均正常显示。
     
      然后单独运行内循环
      
        dA1=某个日期(---此日期A表有记录)。
         n1=1
           scan for A1= dA1 AND A2="AAA"
           cA3=PADL(ALLTRIM(STR(n1,4)),4,"0")
           
              REPLACE A3 WITH cA3
            n1=n1+1
          endscan
          运行正常,所有记录正常写入。
         
          请各位高手帮忙看看指出问题所在处,先谢了。
         
搜索更多相关主题的帖子: AAA 循环 日期 记录 运行 
2021-06-30 10:07
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:10 
例举几条数据记录,根据A1和A2的什么写入想要的A3结果
2021-06-30 10:19
xuminxz
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:40
帖 子:749
专家分:2475
注 册:2011-5-8
得分:10 
第2个scan语句直接将指针移动到最后了。
SELE 表A
irecc=recc()
   SCAN FOR A2="AAA"
       if dA1=A1
          loop
       else
          dA1=A1
       endif
    irecno=min(recno()+1,irecc)
         n1=1
           scan for A1= dA1 AND A2="AAA"
           cA3=PADL(ALLTRIM(STR(n1,4)),4,"0")
           
              REPLACE A3 WITH cA3
            n1=n1+1
          endscan
go irecno
      endscan
没有数据测试过。

dBase有人接盘了。
2021-06-30 15:55
总是出错
Rank: 2
等 级:论坛游民
威 望:1
帖 子:248
专家分:24
注 册:2012-12-24
得分:0 
回复 2楼 吹水佬
已解决,谢谢。
2021-07-01 06:23
总是出错
Rank: 2
等 级:论坛游民
威 望:1
帖 子:248
专家分:24
注 册:2012-12-24
得分:0 
回复 3楼 xuminxz
对的。想了好久才明白。谢谢!
2021-07-01 06:24
总是出错
Rank: 2
等 级:论坛游民
威 望:1
帖 子:248
专家分:24
注 册:2012-12-24
得分:0 
回复 3楼 xuminxz
我是直接把外循环改成了 do while 语句,简单明了。
2021-07-01 06:29
总是出错
Rank: 2
等 级:论坛游民
威 望:1
帖 子:248
专家分:24
注 册:2012-12-24
得分:0 
回复 3楼 xuminxz
这段代码已经收藏了。再次谢谢!
2021-07-01 07:00
sdta
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:江苏省连云港市
等 级:版主
威 望:323
帖 子:9621
专家分:26174
注 册:2012-2-5
得分:0 
看下置顶的帖子年限限制

坚守VFP最后的阵地
2023-02-01 12:44



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




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

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