Foxtable(狐表)用户栏目专家坐堂 → 统计月的起止日期与自然月不同,怎么处理才好!


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

主题:统计月的起止日期与自然月不同,怎么处理才好!

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


加好友 发短信
等级:管理员 帖子:47449 积分:251065 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2015/4/15 8:52:00 [显示全部帖子]

好办,增加一个统计日期列,DataColchanged事件代码设置为:

 

Select Case e.DataCol.name
    Case "日期"
        If e.NewValue Is Nothing Then
            e.DataRow("统计日期") = Nothing
        Else
            Dim dt As Date = e.NewValue
            Dim ds As Integer = 0
            If dt.Day > 25 Then
                Select Case  Date.DaysInMonth(dt.Year,dt.Month)
                    Case 31
                        ds = 6
                    Case 30
                        ds = 5
                    Case 29
                        ds = 4
                    Case 28
                        ds =3
                End Select
            End If
            e.DataRow("统计日期") = dt.AddDays(ds)
        End If
End Select

 

参考文件:

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:管理项目8.rar
 

 

 

以后根据统计日期列进行分组统计即可


[此贴子已经被作者于2015/4/15 8:54:05编辑过]

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


加好友 发短信
等级:管理员 帖子:47449 积分:251065 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2015/4/15 8:59:00 [显示全部帖子]

这样好点:

 

Select Case e.DataCol.name
    Case "日期"
        If e.NewValue Is Nothing Then
            e.DataRow("统计日期") = Nothing
        Else
            Dim dt As Date = e.NewValue
            If dt.Day >  25 Then
                dt = new Date(dt.year,dt.month,1)
                dt= dt.AddMonths(1)
            End If
            e.DataRow("统计日期") = dt
        End If
End Select


 回到顶部