Boa tarde senhores.
CONTEXTUALIZAÇÃO: Fiz um pequeno gerenciador de arquivos para meu setor de licitações e contratos no órgão em que eu trabalho. Nele eu tenho, entre outras consultas, duas, sendo que uma me informam os processos em andamento (A) e outra que informa todos os processos que tramitaram pelo setor(B), informando aqueles que estão em andamento e aqueles concluídos. A primeira consulta é mais simples com menos campos. A segunda consulta além dos dados constantes na consulta (A) constam o nome do vencedor da licitação, o valor estimado e o valor contratado .
As duas consultas tem campos chamados DataEntrada e DataSaida e apenas na consulta (B) usei a função copiada em módulo descrita abaixo.
O QUE QUERO: que nas duas consultas seja mostrado o numero de dias úteis que o processo ou levou para ser concluído ou, caso não tenho sido concluído, que me retorne o número de dias úteis até a data da consulta.
PROBLEMA: Na consulta (B) quando o meu processo ainda não está concluso eu não tenho, logicamente, um registro no campo DataSaida, fazendo com que seja retornado um erro no campo Tempo Decorrido.
Na consulta (A) ainda não utilizei nenhum tipo de função e logicamente ainda não está funcionando.
Imagino que para os senhores seja um problema fácil de ser resolvido, mas não sou da área de TI o que consegui fazer até agora foi movido apenas pela curiosidade e a vontade de acertar.
Obrigado pela atenção de todos.
_____________________________________________________________________________________
Public Function DTS(DataEntrada As Date, DataSaída As Date, Optional HojeTb As Boolean = False, Optional UltTb As Boolean = False) As Integer
'....................................................................
' Nome: DTS
' Entradas: DataEntrada As Date
' DataSaída As Date
' HojeTb As Boolean
' UltTb As Boolean
' Saída: Integer
' Autor: Arvin Meyer
' Data: Maio 5,2002
' Comentário: Aceita duas datas e devolve o número de dias úteis
' entre elas. Note-se que esta função considera os feriados
' do período. Ela exige a existência de uma tabela chamada
' tblFeriados com um campo, no formato data, chamado FerData.
' Se HojeTb = True, a data inicial também será considerada.
' Se UltTb = true, a data final também será considerada.
'....................................................................
On Error GoTo Err_DTS
Dim intCount As Integer
Dim rst As DAO.Recordset
Dim DB As DAO.Database
Set DB = CurrentDb
Set rst = DB.OpenRecordset("SELECT [FerData] FROM tblFeriados", dbOpenSnapshot)
If Not HojeTb Then
DataEntrada = DataEntrada + 1
End If
' Se desejar contar a data de início, passe True em HojeTb
intCount = 0
If UltTb Then
Do While DataEntrada <= DataSaída
rst.FindFirst "[FerData] = #" & Format(DataEntrada, "mm/dd/yyyy") & "#"
If Weekday(DataEntrada) <> vbSunday And Weekday(DataEntrada) <> vbSaturday Then
If rst.NoMatch Then intCount = intCount + 1
End If
DataEntrada = DataEntrada + 1
Loop
Else
Do While DataEntrada < DataSaída
rst.FindFirst "[FerData] = #" & Format(DataEntrada, "mm/dd/yyyy") & "#"
If Weekday(DataEntrada) <> vbSunday And Weekday(DataEntrada) <> vbSaturday Then
If rst.NoMatch Then intCount = intCount + 1
End If
DataEntrada = DataEntrada + 1
Loop
End If
DTS = intCount
Exit_DTS:
Exit Function
Err_DTS:
Select Case Err
Case Else
MsgBox Err.Description
Resume Exit_DTS
End Select
End Function
'*********** Code End **************
CONTEXTUALIZAÇÃO: Fiz um pequeno gerenciador de arquivos para meu setor de licitações e contratos no órgão em que eu trabalho. Nele eu tenho, entre outras consultas, duas, sendo que uma me informam os processos em andamento (A) e outra que informa todos os processos que tramitaram pelo setor(B), informando aqueles que estão em andamento e aqueles concluídos. A primeira consulta é mais simples com menos campos. A segunda consulta além dos dados constantes na consulta (A) constam o nome do vencedor da licitação, o valor estimado e o valor contratado .
As duas consultas tem campos chamados DataEntrada e DataSaida e apenas na consulta (B) usei a função copiada em módulo descrita abaixo.
O QUE QUERO: que nas duas consultas seja mostrado o numero de dias úteis que o processo ou levou para ser concluído ou, caso não tenho sido concluído, que me retorne o número de dias úteis até a data da consulta.
PROBLEMA: Na consulta (B) quando o meu processo ainda não está concluso eu não tenho, logicamente, um registro no campo DataSaida, fazendo com que seja retornado um erro no campo Tempo Decorrido.
Na consulta (A) ainda não utilizei nenhum tipo de função e logicamente ainda não está funcionando.
Imagino que para os senhores seja um problema fácil de ser resolvido, mas não sou da área de TI o que consegui fazer até agora foi movido apenas pela curiosidade e a vontade de acertar.
Obrigado pela atenção de todos.
_____________________________________________________________________________________
Public Function DTS(DataEntrada As Date, DataSaída As Date, Optional HojeTb As Boolean = False, Optional UltTb As Boolean = False) As Integer
'....................................................................
' Nome: DTS
' Entradas: DataEntrada As Date
' DataSaída As Date
' HojeTb As Boolean
' UltTb As Boolean
' Saída: Integer
' Autor: Arvin Meyer
' Data: Maio 5,2002
' Comentário: Aceita duas datas e devolve o número de dias úteis
' entre elas. Note-se que esta função considera os feriados
' do período. Ela exige a existência de uma tabela chamada
' tblFeriados com um campo, no formato data, chamado FerData.
' Se HojeTb = True, a data inicial também será considerada.
' Se UltTb = true, a data final também será considerada.
'....................................................................
On Error GoTo Err_DTS
Dim intCount As Integer
Dim rst As DAO.Recordset
Dim DB As DAO.Database
Set DB = CurrentDb
Set rst = DB.OpenRecordset("SELECT [FerData] FROM tblFeriados", dbOpenSnapshot)
If Not HojeTb Then
DataEntrada = DataEntrada + 1
End If
' Se desejar contar a data de início, passe True em HojeTb
intCount = 0
If UltTb Then
Do While DataEntrada <= DataSaída
rst.FindFirst "[FerData] = #" & Format(DataEntrada, "mm/dd/yyyy") & "#"
If Weekday(DataEntrada) <> vbSunday And Weekday(DataEntrada) <> vbSaturday Then
If rst.NoMatch Then intCount = intCount + 1
End If
DataEntrada = DataEntrada + 1
Loop
Else
Do While DataEntrada < DataSaída
rst.FindFirst "[FerData] = #" & Format(DataEntrada, "mm/dd/yyyy") & "#"
If Weekday(DataEntrada) <> vbSunday And Weekday(DataEntrada) <> vbSaturday Then
If rst.NoMatch Then intCount = intCount + 1
End If
DataEntrada = DataEntrada + 1
Loop
End If
DTS = intCount
Exit_DTS:
Exit Function
Err_DTS:
Select Case Err
Case Else
MsgBox Err.Description
Resume Exit_DTS
End Select
End Function
'*********** Code End **************