Foxtable(狐表)用户栏目专家坐堂 → 代码简化


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

主题:代码简化

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


加好友 发短信
等级:七尾狐 帖子:1551 积分:10061 威望:0 精华:0 注册:2014/12/18 16:12:00
代码简化  发帖心情 Post By:2019/1/5 9:01:00 [只看该作者]

If dr("制造产品号").Substring(5,2) = "06" Or dr("制造产品号").Substring(5,2) = "08" Or dr("制造产品号").Substring(5,2) = "10" Or dr("制造产品号").Substring(5,2) = "12"or dr("制造产品号").Substring(5,2) = "13"or dr("制造产品号").Substring(5,2) = "16"or dr("制造产品号").Substring(5,2) = "20" Or dr("制造产品号").contains("600") Or dr("制造产品号").contains("800") Or dr("制造产品号").contains("1000") Or dr("制造产品号").contains("1250") Or dr("制造产品号").contains("1350") Or dr("制造产品号").contains("1600") Or dr("制造产品号").contains("2000")

上面这句代码,Or dr("制造产品号").Substring(5,2) = 和 Or dr("制造产品号").contains 都会重复出现,看起来眼花缭乱,如何简化一下这句代码呢?谢谢。

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


加好友 发短信
等级:六尾狐 帖子:1347 积分:9817 威望:0 精华:0 注册:2015/6/30 8:46:00
  发帖心情 Post By:2019/1/5 9:11:00 [只看该作者]

Dim S1() As String = {"06","08"}
Dim S2() As String = {"0600","1600","2000"}
If s1.contains(dr("制造产品号").Substring(5,2)) OrElse s2.contains(dr("制造产品号").Substring(5,4)) Then

试试
[此贴子已经被作者于2019/1/5 9:12:15编辑过]

 回到顶部
帅哥,在线噢!
有点蓝
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110558 积分:562680 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/1/5 9:20:00 [只看该作者]

Dim arr() As String = {"06","08","10"}
Dim arr1() As String = {"600","800","1000"}
Dim contain As Boolean
Dim sph As sting = dr("制造产品号")
contain = Array.IndexOf(arr,sph.Substring(5,2)) > -1
If not contain Then
    For Each ar As String In arr1
        If sph.contains(ar) Then
            contain = True
            Exit
        End If
    Next
End If
If contain Then
其他处理
End If

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


加好友 发短信
等级:六尾狐 帖子:1347 积分:9817 威望:0 精华:0 注册:2015/6/30 8:46:00
  发帖心情 Post By:2019/1/5 9:36:00 [只看该作者]

If not contain Then  老师,请教一下,这句怎么理解 


 回到顶部
帅哥,在线噢!
有点蓝
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:110558 积分:562680 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2019/1/5 9:42:00 [只看该作者]

等同于

If contain = false Then

 回到顶部