Foxtable(狐表)用户栏目专家坐堂 → 如何根据级码层次自动编号?


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

主题:如何根据级码层次自动编号?

帅哥,在线噢!
有点蓝
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:超级版主 帖子:109736 积分:558396 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/2/28 14:37:00 [显示全部帖子]

把级码拆分,直接补0 即可

Dim jm As String = "1.2.1"
Dim sr() As String = jm.split(".")
Dim s As String = "2020"
For Each s1 As String In sr
    s = s & s1.PadLeft(3,"0")
Next
msgbox(s)

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


加好友 发短信
等级:超级版主 帖子:109736 积分:558396 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/2/28 14:49:00 [显示全部帖子]

生成级码看2楼,然后根据级码转换为编码,看3楼

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


加好友 发短信
等级:超级版主 帖子:109736 积分:558396 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/2/28 15:51:00 [显示全部帖子]

Select e.DataCol.Name
    Case "级码"
        If e.DataRow.IsNull("级码") OrElse e.DataRow.IsNull("编号")=False Then
        Else
            Dim lb As String = e.DataRow("级码")
            Dim max As String
            Dim idx As Integer
            If lb.contains(".") = False Then
                max = e.DataTable.Compute("Max(编号)","len(编号) = 7 And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大编号
                If max > "" Then '如果存在最大编号
                    idx = CInt(max.Substring(max.Length - 3)) + 1 '获得最大编号的后三位顺序号,并加1
                Else
                    idx = 1 '否则顺序号等于1
                End If
                e.DataRow("编号") = Date.Today.year & Format(idx,"000")
            Else
                Dim sr() As String = lb.split(".")
                sr(sr.Length - 1) = ""
                lb = String.join(".",sr).trim()
                Dim len As Integer = 4 + sr.Length * 3
                max = e.DataTable.Compute("Max(编号)","len(编号) = " & len & " And 级码 like '" & lb & "%' And [_Identify] <> " & e.DataRow("_Identify")) '取得该类别的最大编号
                If max > "" Then '如果存在最大编号
                    lb = max.Substring(0,max.Length - 3)
                    idx = CInt(max.Substring(max.Length - 3)) + 1 '获得最大编号的后三位顺序号,并加1
                Else
                    idx = 1 '否则顺序号等于1
                    lb = Date.Today.year
                    For i As Integer = 0 To sr.Length - 2
                        lb = lb & sr(i).PadLeft(3,"0")
                    Next
                End If
                e.DataRow("编号") = lb & Format(idx,"000")
            End If
            
        End If
End Select

 回到顶部