Foxtable(狐表)用户栏目专家坐堂 → 关于考勤数据指定格式生成表格(项目已经改成内部表了!))


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

主题:关于考勤数据指定格式生成表格(项目已经改成内部表了!))

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


加好友 发短信
等级:管理员 帖子:47448 积分:251060 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/7/17 15:46:00 [显示全部帖子]

我理你,命令窗口执行:

 

 

Dim dt1 As Date = #6/8/2011#
Dim dt2 As Date = #12/31/2011#
Dim dtb As New DataTableBuilder("统计")
dtb.AddDef("name", Gettype(String), 32)
dtb.AddDef("cardno", Gettype(String), 32)
dtb.AddDef("date", Gettype(Date))
dtb.AddDef("t1", Gettype(String))
dtb.AddDef("t2", Gettype(String))
dtb.Build
For Each dr1 As DataRow In DataTables("ZlEmployee").DataRows
    For i As Integer = 0 To (dt2 - dt1).TotalDays
        Dim drs As List(of DataRow) =  DataTables("Kq_Source").Select("CardNo = '" & dr1("CardNo") & "'And FDateTime = #" & dt1.AddDays(i) & "#")
        For n As Integer = 0 To drs.count -1
            Dim dr2 As DataRow = DataTables("统计").Addnew
            dr2("name") = dr1("Name")
            dr2("CardNo") = dr1("CardNo")
            dr2("date") = drs(n)("FDateTime").Date
            If n = 0 Then
                dr2("t1") = Format(drs(n)("FDateTime"),"HH:mm")
            ElseIf n =1then
                dr2("t2") = Format(drs(n)("FDateTime"),"HH:mm")
                Exit For
            End If
        Next
    Next
Next


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


加好友 发短信
等级:管理员 帖子:47448 积分:251060 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/8/2 10:32:00 [显示全部帖子]

Dim drs As List(of DataRow) =  DataTables("Kq_Source").Select("CardNo = '" & dr1("CardNo") & "'And FDateTime = #" & dt1.AddDays(i) & "#")

 

改为:

 

Dim drs As List(of DataRow) =  DataTables("Kq_Source").Select("CardNo = '" & dr1("CardNo") & "'And FDateTime >= #" & dt1.AddDays(i) & "# And FDateTime < #" & dt1.AddDays(i +1) & "# ")

 

 


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


加好友 发短信
等级:管理员 帖子:47448 积分:251060 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2013/8/2 11:51:00 [显示全部帖子]

Dim dt1 As Date = #6/10/2011#
Dim dt2 As Date = #6/12/2011#
Dim dtb As New DataTableBuilder("统计")
dtb.AddDef("name", Gettype(String), 32)
dtb.AddDef("cardno", Gettype(String), 32)
dtb.AddDef("date", Gettype(Date))
dtb.AddDef("t1", Gettype(String))
dtb.AddDef("t2", Gettype(String))
dtb.Build
For Each dr1 As DataRow In DataTables("ZlEmployee").DataRows
    For i As Integer = 0 To (dt2 - dt1).TotalDays
        Dim dr2 As DataRow
        dr2 = DataTables("统计").Addnew
        dr2("name") = dr1("Name")
        dr2("CardNo") = dr1("CardNo")
        dr2("date") = dt1.AddDays(i)
        Dim drs As List(of DataRow) =  DataTables("Kq_Source").Select("CardNo = '" & dr2("CardNo") & "'And FDateTime >= #" & dr2("Date") & "# And FDateTime < #" & dr2("Date").AddDays(1) & "# ")
        For n As Integer = 0 To drs.count -1
            If n = 0 Then
                dr2("t1") = Format(drs(n)("FDateTime"),"HH:mm")
            ElseIf n =1 Then
                dr2("t2") = Format(drs(n)("FDateTime"),"HH:mm")
                Exit For
            End If
        Next
    Next
Next

 回到顶部