Foxtable(狐表)用户栏目专家坐堂 → [求助]想学习下集合的使用,执行结果想不明白了


  共有3519人关注过本帖树形打印复制链接

主题:[求助]想学习下集合的使用,执行结果想不明白了

帅哥哟,离线,有人找我吗?
huangfanzi
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
[求助]想学习下集合的使用,执行结果想不明白了  发帖心情 Post By:2015/1/9 11:09:00 [显示全部帖子]

Dim drs As List(Of DataRow) = DataTables("工序合并表").Select("母卷号 = 'CD141208'", "卷号,起始时间")
drs(0)("投料量")=drs(0)("重量")
For i As Integer = 1 To drs.Count - 1
    If drs(i)("卷号").Contains(drs(i-1)("卷号")) Then
        drs(i)("投料量") = drs(i-1)("投料量")
    Else
        drs(i)("投料量") = 0
    End If
Next

 

用上面代码,按理图中红框处应该是0啊

 


图片点击可在新窗口打开查看此主题相关图片如下:例子图.jpg
图片点击可在新窗口打开查看

 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 11:26:00 [显示全部帖子]

BIN老师,母卷号指的就是卷号前8位,上面的图没有截完整,在这个表上有个母卷号列,对应上图中的几条记录,母卷号全为CD141208

我估计是没搞明白Contains这个方法,为了便于是描述,我把实际卷号放到公式中请老师指导下

If drs(i)("CD141208A").Contains(drs(i-1)("CD141208")) Then  这个公式中,返回的值是T还是F,也就是说 Contains的方法在执行时,是判断CD141208A=CD141208 还是CD141208A包含CD141208


 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 11:43:00 [显示全部帖子]

有点甜老师的代码是执行正确的,但思维有点混乱,请帮我解读一下这条语句:

 

If drs(i)("卷号").Contains(drs(i-1)("卷号")) 

把值代码公式后变为:

If drs(2)("CD1410001A").Contains(drs(1)("CD140001"))

 

我的解读是:如果集合drs中的第二条记录中的卷号(即CD1410001A)能在此集合第一条记录中的卷号(即CD1410001)中找到,按我的解读,这条语句执行后得到的是 F

[此贴子已经被作者于2015-1-9 11:43:33编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 11:54:00 [显示全部帖子]

有点甜老师,你所说的通过下一轮判断来修正上一轮结果,我看懂了,现在不明白的是

If drs(2)("CD1410001A").Contains(drs(1)("CD140001"))  这条语句在本轮执行时,返回的结果是T,我通过修改你给我的代码的FOR步长(For i As Integer = 1 To 3 )验证过了,可我对这条语句的理解有偏差。根据帮助文件,用Contains方法是通过包括来判断的,并不是字符串的包含

Contains 方法 判断集合中是否包括某个值


 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 12:22:00 [显示全部帖子]

 

步长为3时的结果


图片点击可在新窗口打开查看此主题相关图片如下:例子图a.jpg
图片点击可在新窗口打开查看

 

步长为4时的结果

图片点击可在新窗口打开查看此主题相关图片如下:例子图b.jpg
图片点击可在新窗口打开查看

由此可见,在执行本轮判断时,返回的是T,在进行下一轮判断时,修改了上一轮的结果


 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 14:19:00 [显示全部帖子]

Dim drs As List(Of DataRow) = DataTables("工序合并表").Select("母卷号 = 'CD141208'", "卷号,起始时间")
drs(0)("投料量")=drs(0)("重量")
For i As Integer = 1 To 3

当i值为3时:


    If drs(3)("
CD141208A").Contains(drs(2)("CD141208")) Then  就是这一步,我的理解是返回F,但运算结果返回了T

        drs(3)("投料量") = drs(2)("投料量")  返回T后,执行了这一步,导致CD141208A的投料量中有了110
    Else
        drs(i-1)("投料量") = 0
    End If
Next


 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 14:29:00 [显示全部帖子]

如果这个方法的运行是用包含进行运算,哪就没问题了,但关于集合的帮助文件中是
Contains方法判断集合中是否包括某个值

包括与包含是二个概念,这就是我搞糊涂的地方。

 回到顶部
帅哥哟,离线,有人找我吗?
huangfanzi
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/1/9 14:37:00 [显示全部帖子]

好吧,甜老师,我错了,原来代码中的这个方法不是集合中Contains的方法,顺便再大赞一下甜老师帮我改了关于库存标记的代码,全表运行只要1秒,之前的老代码要用30多秒。

 回到顶部