Foxtable(狐表)用户栏目专家坐堂 → 按月生成编号,最后一天不能自动生成


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

主题:按月生成编号,最后一天不能自动生成

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


加好友 发短信
等级:五尾狐 帖子:1028 积分:7191 威望:0 精华:0 注册:2016/6/16 15:23:00
按月生成编号,最后一天不能自动生成  发帖心情 Post By:2020/8/10 10:43:00 [只看该作者]

请老师指点:按帮助做的代码,按月生成编号,最后一天不能自动生成。

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


加好友 发短信
等级:五尾狐 帖子:1028 积分:7191 威望:0 精华:0 注册:2016/6/16 15:23:00
  发帖心情 Post By:2020/8/10 10:43:00 [只看该作者]

请老师指点:按帮助做的代码,按月生成编号,最后一天不能自动生成。


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


加好友 发短信
等级:五尾狐 帖子:1028 积分:7191 威望:0 精华:0 注册:2016/6/16 15:23:00
  发帖心情 Post By:2020/8/10 10:45:00 [只看该作者]

If e.Dat\aCol.Name = "日期" Then

    If\ e.Data\Row.IsNull("日期") Then

        e.Data\Row("编号") = Nothing

    Else

        Dim d As Da\te = e.D\ataRow("日期")

        Dim y As Int\eger = d.Year

        Dim m As In\teger = d.Month

        Dim Days As Integer = Da\te.DaysInMonth(y,m)

        Dim fd As Date = New Dat\e(y,m,1) '获得该月的第一天

        Dim ld As Date = New Dat\e(y,m,Days) '获得该月的最后一天

        Dim bh As String = For\mat(d,"yyyyMM") '生成编号的前6位,4位年,2位月.

        If e.Data\Row("编号").Star\sWith(bh) = False '如果编号的前6位不符

            Dim max As St\ring

            Dim idx As Integ\er

            max = e.DataT\\able.Comp\ute("Max(编号)","日期 >= #" & fd & "# And 日期 <= #" & ld & "# And [_Iden\tify] <> " & e.DataRo\w("_Identify")) '取得该月的最大编号

            If max > "" Then '如果存在最大编号

                idx = CInt(max.Subst\ring(7,3)) + 1 '获得最大编号的后三位顺序号,并加1

            Else

                idx = 1 '否则顺序号等于1

            End If

            e.Data\Row("编号") = bh & "-" & For\mat(idx,"000")

        End If

    End If

End If



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


加好友 发短信
等级:超级版主 帖子:110560 积分:562690 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2020/8/10 11:12:00 [只看该作者]

如果日期有时分秒,这样

max = e.DataT\\able.Comp\ute("Max(编号)","日期 >= #" & fd & "# And 日期 < #" & ld.adddays(1) & "# And [_Iden\tify] <> " & e.DataRo\w("_Identify")) '取得该月的最大编号

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


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

试过,没有问题,不过你的判断条件最好更改一下

If e.DataRow("编号").StartsWith(bh) = False OrElse e.DataRow.IsNull("编号") then'如果编号的前6位不符

 


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


加好友 发短信
等级:五尾狐 帖子:1028 积分:7191 威望:0 精华:0 注册:2016/6/16 15:23:00
  发帖心情 Post By:2020/8/10 11:35:00 [只看该作者]

谢谢老师指点。

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


加好友 发短信
等级:狐精 帖子:3205 积分:21299 威望:0 精华:0 注册:2016/3/28 16:57:00
  发帖心情 Post By:2020/8/10 14:25:00 [只看该作者]

以下是引用2900819580在2020/8/10 11:17:00的发言:

试过,没有问题,不过你的判断条件最好更改一下

If e.DataRow("编号").StartsWith(bh) = False OrElse e.DataRow.IsNull("编号") then'如果编号的前6位不符

 

有问题,如果日期列是长时间格式,最后一天是有问题。你那样判断只是当有编号列不在重新生成而已,需要像有点蓝老师的那个方法处理

[此贴子已经被作者于2020/8/10 14:26:05编辑过]

 回到顶部