亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? frmrpttimepos.frm

?? 考勤機管理軟件,用于統計某段時間某個部門或者某個員工在某段內遲到與早退次數.
?? FRM
?? 第 1 頁 / 共 2 頁
字號:
                GetWeekday (dBeginDate)
                
                '===========獲得該刷卡日期所擁有班次===========
                bTime = Mid(bTime, 1, 4) & Mid(bTime, 6, 2) & Mid(bTime, 9, 2)
                GetSetClassID EmployeeInfo(lEmpRow).CardID, bTime
                
                '===========獲得該刷卡日期刷卡次數=================
                rstGrid.Fields("刷卡次數") = GetClassCount()
                
                rstGrid.Fields("員工卡號") = EmployeeInfo(lEmpRow).CardID
                rstGrid.Fields("員工名稱") = EmployeeInfo(lEmpRow).EmployeeName
                 
'                If rstGrid.Fields("刷卡次數") = 0 Then
'                    rstGrid.Fields("說明") = "班次時間設定有誤,不能正常輸出!"
'                    GoTo NextFor
'                End If
                If rstGrid.Fields("刷卡次數") = 0 Then GoTo NextFor
                
                If rstGrid.Fields("刷卡次數") = -1 Then
                    rstGrid.Fields("說明") = "時間段設置有沖突!"
                    GoTo NextFor
                End If

'                Dim ClassIDCount As Long
'                Dim ClassIDIndex As Long
'                sClassID = ""
'                ClassIDCount = UBound(ClassIDInfo)
'                For ClassIDIndex = 1 To ClassIDCount
'                    sClassID = sClassID & CStr(ClassIDInfo(ClassIDIndex).ClassID) & ","
'                Next
'
'                sClassID = Left(sClassID, Len(sClassID) - 1)
'
'                If rstExec.State = 1 Then rstExec.Close
'                Set rstExec = Nothing
'                rstExec.CursorLocation = adUseClient
'                rstExec.Open "select ClassName  from Class where ClassID in (" & sClassID & ")", con, adOpenStatic, adLockBatchOptimistic
'                sClassID = ""
'                If rstExec.RecordCount > 0 Then
'                    rstExec.MoveFirst
'                    While Not rstExec.EOF
'                        sClassID = sClassID & rstExec.Fields("ClassName") & "  "
'                        rstExec.MoveNext
'                    Wend
'
'                End If
'
'
'                rstGrid.Fields("班次組合") = sClassID

                Dim tmpClassCount As Long
                Dim tmpClassIndex As Long
                If blntmpClassInfo = True Then
                    tmpClassCount = UBound(tmpClassInfo)
                    For tmpClassIndex = 1 To tmpClassCount
                    
                        bln(tmpClassIndex) = True
                        rstGrid.Fields("時間" & tmpClassIndex * 2 - 1) = GetTime(tmpClassInfo(tmpClassIndex).bTime)
                        rstGrid.Fields("時間" & tmpClassIndex * 2) = GetTime(tmpClassInfo(tmpClassIndex).eTime)
                        rstGrid.Fields("所屬班次" & tmpClassIndex * 2 - 1) = GetClassName(tmpClassInfo(tmpClassIndex).ClassID)
                        
                        
                        
                        If tmpClassInfo(tmpClassIndex).AddClass = True Then
                        
                            If GetYesNoLeave(EmployeeInfo(lEmpRow).EmployeeID, tmpClassIndex * 2, sDate) = True Then
                                rstGrid.Fields("備注" & tmpClassIndex * 2 - 1) = "請假"
                            Else
                                rstGrid.Fields("備注" & tmpClassIndex * 2 - 1) = "加班"
                            End If
                            
                        Else
                        
                            If GetYesNoVac(EmployeeInfo(lEmpRow).EmployeeID, tmpClassIndex * 2, EmployeeInfo(lEmpRow).VacID, sDate) = True Then
                                rstGrid.Fields("備注" & tmpClassIndex * 2 - 1) = "休假"
                            Else
                                If GetYesNoLeave(EmployeeInfo(lEmpRow).EmployeeID, tmpClassIndex * 2, sDate) = True Then
                                    rstGrid.Fields("備注" & tmpClassIndex * 2 - 1) = "請假"
                                Else
                                    rstGrid.Fields("備注" & tmpClassIndex * 2 - 1) = ""
                                End If
                            End If
                
                        End If
                        

                        
                    Next
    
                End If
NextFor:
                
                rstGrid.Update
            
            End If

        Next

        dBeginDate = dBeginDate + 1
    Loop
    
    
    Grid.DefSortCol = "刷卡日期"
'    Grid.Col("Date").SortDirection = sASC
'    MsgBox rstGrid.RecordCount
    
    For i = 1 To UBound(bln)
        Grid.Col("時間" & i * 2 - 1).Visible = bln(i)
        Grid.Col("時間" & i * 2).Visible = bln(i)
        Grid.Col("所屬班次" & i * 2 - 1).Visible = bln(i)
        Grid.Col("備注" & i * 2 - 1).Visible = bln(i)
    Next
    
    Set Grid.DataSource = rstGrid

End Sub







Private Function GetTime(ByVal sTime As String) As String
    Dim a As Integer
    Dim b As Integer
    
    a = Int(Val(sTime) / 60)
    
    b = Int(Val(sTime) Mod 60)
    
    GetTime = Right("00" & a, 2) & ":" & Right("00" & b, 2)
End Function

Private Sub SetGrid(ByVal TimeCount As Long)

    If rstGrid.State = adStateOpen Then rstGrid.Close
    Set rstGrid = Nothing
    Dim i As Long
    For i = 1 To rstGrid.Fields.Count
        rstGrid.Fields.Delete i
    Next
    
    rstGrid.Fields.Append "員工名稱", adVarChar, 20
    rstGrid.Fields.Append "員工卡號", adVarChar, 20
    rstGrid.Fields.Append "刷卡日期", adVarChar, 20
    rstGrid.Fields.Append "星期", adVarChar, 20
    rstGrid.Fields.Append "刷卡次數", adInteger

    
    Grid.ClearHeadData
'    Grid.AddHeader "序號", "Serial", 40, -1, "Serial", False, sSerial
'    Grid.AddHeader "刷卡日期", "Date", 90, -1, "刷卡日期", False, sDefault
'    Grid.AddHeader "星期", "Weekday", 20, -1, "星期", False, sDefault
'    Grid.AddHeader "員工卡號", "Card", 60, -1, "員工卡號", False, sDefault
'    Grid.AddHeader "員工名稱", "Name", 60, -1, "員工名稱", False, sDefault
'    Grid.AddHeader "刷卡次數", "CardCount", 60, -1, "刷卡次數", False, sDefault
    
    Grid.AddHeader "序號", "序號", 40, -1, "Serial", False, sSerial
    Grid.AddHeader "刷卡日期", "刷卡日期", 90, -1, "刷卡日期", False, sDefault
    Grid.AddHeader "星期", "星期", 20, -1, "星期", False, sDefault
    Grid.AddHeader "員工卡號", "員工卡號", 60, -1, "員工卡號", False, sDefault
    Grid.AddHeader "員工名稱", "員工名稱", 60, -1, "員工名稱", False, sDefault
    Grid.AddHeader "刷卡次數", "刷卡次數", 60, -1, "刷卡次數", False, sDefault
    
    Dim intField As Integer
    
    For intField = 1 To TimeCount * 2 Step 2
    
        rstGrid.Fields.Append "時間" & intField, adVarChar, 20
        rstGrid.Fields.Append "時間" & intField + 1, adVarChar, 20
        
        rstGrid.Fields.Append "所屬班次" & intField, adVarChar, 20
        rstGrid.Fields.Append "備注" & intField, adVarChar, 20
        
        Grid.AddHeader "上班時間", "時間" & intField, 80, -1, "時間" & intField, False, sDefault
        Grid.AddHeader "下班時間", "時間" & intField + 1, 80, -1, "時間" & intField + 1, False, sDefault

        Grid.AddHeader "所屬班次", "所屬班次" & intField, 80, -1, "所屬班次" & intField, False, sDefault
        Grid.AddHeader "備注", "備注" & intField, 80, -1, "備注" & intField, False, sDefault



        Grid.AddCollect "時間段" & (intField + 1) / 2, "KeyOne" & intField
        Grid.Col("時間" & intField).CollectKey = "KeyOne" & intField
        Grid.Col("時間" & intField + 1).CollectKey = "KeyOne" & intField
        Grid.Col("所屬班次" & intField).CollectKey = "KeyOne" & intField
        Grid.Col("備注" & intField).CollectKey = "KeyOne" & intField
    Next
    
    rstGrid.Fields.Append "說明", adVarChar, 255
    Grid.AddHeader "說明", "說明", 120, -1, "說明", False, sDefault
    
    
    rstGrid.Open "", , adOpenStatic, adLockBatchOptimistic
    
    Grid.HeadHeight = 40
    Grid.AllowAddNew = False
    
    Grid.GroupCol = 4
    
    Grid.Col("序號").SumText = "合計"
    Grid.SmallSumText = "小計"

End Sub


Private Sub GetWeekday(ByVal dBeginDate As Date)
    Select Case Weekday(dBeginDate)
    
        Case 1
            rstGrid.Fields("星期") = "日"
        Case 2
            rstGrid.Fields("星期") = "一"
        Case 3
            rstGrid.Fields("星期") = "二"
        Case 4
            rstGrid.Fields("星期") = "三"
        Case 5
            rstGrid.Fields("星期") = "四"
        Case 6
            rstGrid.Fields("星期") = "五"
        Case 7
            rstGrid.Fields("星期") = "六"
            
    End Select
End Sub

Private Sub Form_Unload(Cancel As Integer)
    If rstGrid.State = 1 Then rstGrid.Close
    Set rstGrid = Nothing
    If rstExec.State = 1 Then rstExec.Close
    Set rstExec = Nothing
End Sub

Private Sub Form_Resize()
On Error Resume Next

    Frame.Move 60, 0, Me.ScaleWidth - 120, 800
    
    lblEmployee.Move 60, 300
    cmbEmployee.Move lblEmployee.Left + lblEmployee.Width + 60, lblEmployee.Top - 30
    
    lblBeginDate.Move cmbEmployee.Left + cmbEmployee.Width + 60, lblEmployee.Top
    dtpBeginDate.Move lblBeginDate.Left + lblBeginDate.Width + 60, lblEmployee.Top - 30

'    lblBeginDate.Move 60, 300
'    dtpBeginDate.Move lblBeginDate.Left + lblBeginDate.Width + 60, lblBeginDate.Top - 30
    
    
    lblEndDate.Move dtpBeginDate.Left + dtpBeginDate.Width + 60, lblEmployee.Top
    dtpEndDate.Move lblEndDate.Left + lblEndDate.Width + 60, lblEmployee.Top - 30

'    cmdQuery.Move dtpEndDate.Left + dtpEndDate.Width + 60, lblEmployee.Top - 60
'    cmdQuery.Move Frame.Width - cmdQuery.Width - 100, lblEmployee.Top - 60
    
    cmdPrint.Move Frame.Width - cmdQuery.Width - 100, lblEmployee.Top - 90
    cmdExpor.Move cmdPrint.Left - cmdExpor.Width - 60, lblEmployee.Top - 90
    cmdQuery.Move cmdExpor.Left - cmdQuery.Width - 60, lblEmployee.Top - 90
    
    Grid.Move 0, Frame.Top + Frame.Height, Me.ScaleWidth, Me.ScaleHeight - Frame.Height
End Sub


Public Sub PrintBill()
    If rstGrid.State <> adStateOpen Then Exit Sub
    
    Dim i As Integer
    Dim j As Integer
    For i = 1 To UBound(bln)
        If bln(i) = True Then j = j + 1
    Next
    j = j * 2
    Grid.SortOutRst
    ACRptEngine1.Init
    ACRptEngine1.AddDataSet "ac", rstGrid
    
    If j = 0 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos0.apt"
    ElseIf j = 2 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos02.apt"
    ElseIf j = 4 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos04.apt"
    ElseIf j = 6 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos06.apt"
    ElseIf j = 8 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos08.apt"
    End If
    
    ACRptEngine1.PrintReport
End Sub

Public Sub PreviewBill()
    If rstGrid.State <> adStateOpen Then Exit Sub
    
    Dim i As Integer
    Dim j As Integer
    For i = 1 To UBound(bln)
        If bln(i) = True Then j = j + 1
    Next
    j = j * 2
    
    Grid.SortOutRst
    ACRptEngine1.Init
    ACRptEngine1.AddDataSet "ac", rstGrid
        
    
    If j = 0 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos00.apt"
    ElseIf j = 2 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos02.apt"
    ElseIf j = 4 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos04.apt"
    ElseIf j = 6 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos06.apt"
    ElseIf j = 8 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos08.apt"
    End If
    
    ACRptEngine1.Preview

End Sub

Public Sub ShowDesignerBill()
    If rstGrid.State <> adStateOpen Then Exit Sub
    
    Dim i As Integer
    Dim j As Integer
    For i = 1 To UBound(bln)
        If bln(i) = True Then j = j + 1
    Next
    j = j * 2
    Grid.SortOutRst
    ACRptEngine1.Init
    ACRptEngine1.AddDataSet "ac", rstGrid
    
    If j = 0 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos00.apt"
    ElseIf j = 2 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos02.apt"
    ElseIf j = 4 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos04.apt"
    ElseIf j = 6 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos06.apt"
    ElseIf j = 8 Then
        ACRptEngine1.SetReportFile App.Path & "\RPT\RPTPos08.apt"
    End If
    
    ACRptEngine1.ShowDesigner

End Sub

Private Sub Grid_DblClick()
    If Grid.RecordCount = 0 Then
        Message "沒有可用信息!"
        Exit Sub
    End If
    
    If Grid.CurRow = -1 Then
        Message "請先選中數據!"
        Exit Sub
    End If
    
    Load frmRptTimePos_D
    frmRptTimePos_D.ShowBill rstGrid.Fields("刷卡日期"), rstGrid.Fields("星期"), rstGrid.Fields("員工卡號"), rstGrid.Fields("員工名稱")
    frmRptTimePos_D.Show vbModal
End Sub

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天堂久久久久va久久久久| 欧美日韩极品在线观看一区| 一区在线播放视频| 91在线观看污| 美国一区二区三区在线播放| 国产精品久久三| 这里只有精品免费| 91免费看`日韩一区二区| 美日韩一区二区| 亚洲综合成人在线视频| 国产日韩亚洲欧美综合| 色拍拍在线精品视频8848| 国产呦精品一区二区三区网站| 一区二区中文字幕在线| 精品国产乱码久久久久久久久| 91碰在线视频| 国内一区二区视频| 偷拍亚洲欧洲综合| 国产精品国产三级国产有无不卡| 欧美成人三级在线| 欧美日韩激情在线| 91免费观看视频| 国产suv精品一区二区三区| 亚洲h精品动漫在线观看| 亚洲欧洲制服丝袜| 中文字幕精品一区二区三区精品| 91精品国产综合久久蜜臀| 欧美综合色免费| 99久久国产免费看| 粗大黑人巨茎大战欧美成人| 国产一区二区三区免费看| 午夜激情综合网| 亚洲福利国产精品| 亚洲国产精品麻豆| 夜夜嗨av一区二区三区| 亚洲女同一区二区| 亚洲免费av在线| 亚洲日本欧美天堂| 国产精品久久久一区麻豆最新章节| 久久久亚洲午夜电影| 日韩一区二区三区四区| 欧美精品自拍偷拍动漫精品| 欧美色图12p| 99re成人在线| 色婷婷综合久色| 91女人视频在线观看| 91色九色蝌蚪| 91丨九色porny丨蝌蚪| 国产黄人亚洲片| 国产剧情一区二区| 国产剧情av麻豆香蕉精品| 国产一区二区精品久久91| 黑人精品欧美一区二区蜜桃| 精品无码三级在线观看视频| 黄色资源网久久资源365| 国内精品免费**视频| 国产美女av一区二区三区| 国产在线一区二区| 大桥未久av一区二区三区中文| 丰满亚洲少妇av| 成人一级片在线观看| 国产精品一色哟哟哟| 福利91精品一区二区三区| 成人免费视频播放| 色老汉一区二区三区| 欧美另类久久久品| 精品1区2区在线观看| 国产精品人妖ts系列视频| 亚洲欧美日韩国产一区二区三区| 一区二区三区色| 青青草国产精品97视觉盛宴| 国精品**一区二区三区在线蜜桃| 国产sm精品调教视频网站| av电影在线观看一区| 欧美色视频一区| 久久―日本道色综合久久| 欧美国产国产综合| 亚洲国产日日夜夜| 国内外成人在线视频| 色偷偷久久一区二区三区| 欧美一级二级三级蜜桃| 中文一区在线播放| 亚洲成人av一区二区三区| 国产自产高清不卡| 在线观看日韩精品| 精品国产乱码久久| 一区二区成人在线| 国产一区欧美一区| 欧美视频在线观看一区| 欧美精品一区二区在线观看| 亚洲精品国产无套在线观| 日本美女一区二区| 99国产麻豆精品| 欧美不卡视频一区| 亚洲精品综合在线| 国产精品资源在线观看| 欧美日韩国产高清一区二区三区| 国产亚洲短视频| 日韩在线观看一区二区| youjizz国产精品| 日韩欧美国产综合| 一区二区不卡在线视频 午夜欧美不卡在| 久久精品国产秦先生| 在线观看日韩国产| 国产精品卡一卡二卡三| 美脚の诱脚舐め脚责91| 欧洲中文字幕精品| 亚洲国产精品传媒在线观看| 免费高清在线一区| 欧美丝袜自拍制服另类| 亚洲欧洲日产国码二区| 国产乱码精品一区二区三区av| 欧美美女黄视频| 亚洲亚洲精品在线观看| 成人动漫一区二区在线| 久久欧美中文字幕| 久久精品国产99| 欧美卡1卡2卡| 亚洲国产精品尤物yw在线观看| 9色porny自拍视频一区二区| 久久免费视频色| 美女视频黄 久久| 欧美丰满美乳xxx高潮www| 一区二区在线免费观看| 99r精品视频| 日韩美女精品在线| 成人免费视频免费观看| 久久久精品国产免大香伊| 久久激五月天综合精品| 91精品国产综合久久国产大片| 亚洲高清在线精品| 欧洲一区在线观看| 亚洲一区二区成人在线观看| 色又黄又爽网站www久久| 国产精品久久久一本精品 | 成人app在线| 国产亚洲欧美在线| 国产精品一区一区三区| 久久综合色婷婷| 国产综合成人久久大片91| 精品国产三级a在线观看| 久久精品国产999大香线蕉| 欧美mv日韩mv| 国产麻豆视频一区| 国产午夜精品一区二区三区视频| 国产精品一二三四| 国产日产精品一区| 99精品热视频| 亚洲一区二区中文在线| 欧美日韩亚洲综合在线| 日韩在线卡一卡二| 久久综合狠狠综合久久激情 | 亚洲欧美综合另类在线卡通| 成人激情免费视频| 一区二区三区欧美视频| 欧美日韩另类一区| 男男gaygay亚洲| 久久蜜桃一区二区| 99国产一区二区三精品乱码| 一区二区在线观看av| 欧美日韩夫妻久久| 韩国毛片一区二区三区| 中文字幕巨乱亚洲| 日本电影欧美片| 日韩精品久久久久久| 精品国产乱码久久久久久夜甘婷婷 | 国产亚洲va综合人人澡精品 | 欧美一级日韩免费不卡| 精品写真视频在线观看| 中文字幕日韩av资源站| 欧美色网站导航| 久久精品国产亚洲5555| 国产精品日韩成人| 欧美日本在线播放| 国产精品香蕉一区二区三区| 国产精品国产三级国产aⅴ入口| 欧洲av一区二区嗯嗯嗯啊| 麻豆一区二区99久久久久| 国产精品美日韩| 538在线一区二区精品国产| 国产成人综合在线播放| 亚洲另类在线一区| 欧美不卡在线视频| 在线国产电影不卡| 韩国av一区二区三区四区 | 亚洲欧美日韩国产一区二区三区 | 日本欧美在线观看| 日韩一区二区三区免费观看| 国内精品久久久久影院色| 亚洲午夜在线视频| 久久午夜国产精品| 欧美日高清视频| 成人精品小蝌蚪| 亚洲第一激情av| 久久久国产精品午夜一区ai换脸| 欧洲激情一区二区| 成人精品免费看| 美女精品一区二区| 亚洲综合色视频| 国产精品水嫩水嫩|