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


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

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

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


加好友 发短信
等级:一尾狐 帖子:404 积分:5048 威望:0 精华:0 注册:2015/4/30 15:42:00
如何根据级码层次自动编号?  发帖心情 Post By:2022/2/28 14:26:00 [只看该作者]

如何修改帮助文件中的自动编号生成,根据级码不同层次生成不重复编号?
图片点击可在新窗口打开查看此主题相关图片如下:编号.png
图片点击可在新窗口打开查看

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


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2022/2/28 14:32:00 [只看该作者]

升级到最新版本,看起折叠模式,就可以自动生成级码:

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


加好友 发短信
等级:超级版主 帖子:110574 积分:562760 威望: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)

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


加好友 发短信
等级:一尾狐 帖子:404 积分:5048 威望:0 精华:0 注册:2015/4/30 15:42:00
  发帖心情 Post By:2022/2/28 14:42:00 [只看该作者]

我想要生成编号,编号以年为基础向下扩展,比如:1、目录树中增加根节点,保存的时候生成级码4及编号2020004。2、目录树根节点2增加子节点,保存的时候生成级码2.1及编号2020002001。

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


加好友 发短信
等级:超级版主 帖子:110574 积分:562760 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/2/28 14:49:00 [只看该作者]

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

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


加好友 发短信
等级:一尾狐 帖子:404 积分:5048 威望:0 精华:0 注册:2015/4/30 15:42:00
  发帖心情 Post By:2022/2/28 15:06:00 [只看该作者]

有点蓝老师,这样操作如果不插入节点编码是正确的,但是如果是插入节点,这样编码就不行了,编码会存在重复

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


加好友 发短信
等级:一尾狐 帖子:404 积分:5048 威望:0 精华:0 注册:2015/4/30 15:42:00
  发帖心情 Post By:2022/2/28 15:13:00 [只看该作者]

目录树是根据项目来生成,插入节点后项目所对应的级码可以调整,但编号不做调整,按不同层次的最大编号往下编

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


加好友 发短信
等级:一尾狐 帖子:404 积分:5048 威望:0 精华:0 注册:2015/4/30 15:42:00
  发帖心情 Post By:2022/2/28 15:25:00 [只看该作者]

插入根节点获取已存在“年+3位序号”的最大编号,往下编号;子节点上进行插入时节点时获取已存在“父节点编号+3位序号”的最大编号往下编

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


加好友 发短信
等级:超级版主 帖子:110574 积分:562760 威望: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

 回到顶部