Solved

DateDiff question, need count for 8 hours a day including weekends and holidays

Posted on 2008-10-15
4
491 Views
Last Modified: 2008-11-10
Should be pretty simple really, but I am in brainfart mode this am (pardon the expression), lack of caffeine again, I suppose...

I have two dates (startDate and endDate), they represent when a ticket is opened and closed.  There will be a third field to be used later for 'workTime'.  

For each day (24 hour period) in the dateDiff (including holidays and weekends), I need to add 8 hours, then when I have the final number, I need to subtract the value of the 'workTime' field.

chuck
0
Comment
Question by:cwickens
  • 3
4 Comments
 

Expert Comment

by:nmxsupport
ID: 22719992
0
 
LVL 5

Author Comment

by:cwickens
ID: 22720135
It looks like this is only available in MS Project/VBA.  I am using it in a Web App with VB,

Any thoughts on using dateDiff and converting it or a VB example of projectDateDiff?
0
 
LVL 5

Author Comment

by:cwickens
ID: 22720238
ok, I am making progress...  I can use the dateDIff and return the number of days, hours, minutes and seconds.

I get the result as 3.13:30:00  (3 days, 13 hours, 30 minutes, 0 seconds).  I need to parse that result into: 24 (3 8 hour periods) + 8 (in the 13 hour block)  + .5 (for the 30 minute) = 32.5

ugh....thoughts anyone?
    Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim startDate As DateTime = Me.RadStartDateTimePicker.SelectedDate
        Dim endDate As DateTime = Me.RadStartDateTimePicker0.SelectedDate
        Dim totalTime As String = ""
 
        totalTime = endDate.Date.Subtract(startDate).ToString
        Me.LabelTotalTime.Text = totalTime
    End Sub

Open in new window

0
 
LVL 5

Accepted Solution

by:
cwickens earned 0 total points
ID: 22886590
I found the solution, I am using Telerik's radControls and ended up using dateDiff along with regular math to get the values I wanted.  There is probably a better method, however, this works for what I need.
    Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
        If Me.RadStartDateTimePicker.IsEmpty Then
            Me.LabelNoStartDate.Text = "Start Date/Time Required"
            Exit Sub
        ElseIf Me.RadStartDateTimePicker0.IsEmpty Then
            Me.LabelNoStartDate.Text = ""
            Me.LabelNoEndDate.Text = "End Date/Time Required"
            Exit Sub
        Else
            ' get start and end date values
            Dim startDate As DateTime = Me.RadStartDateTimePicker.SelectedDate.Value
            Dim endDate As DateTime = Me.RadStartDateTimePicker0.SelectedDate.Value
 
            ' calculate total event minutes
            Dim totalHours As Double = DateDiff(DateInterval.Hour, startDate, endDate)
 
            ' convert total minutes to 8 hour days
            Dim intTotalHours As Double = totalHours / 3
 
            ' get value of work hours and minutes
            Dim intWorkTime As Double = Me.TextBoxWorkTime.Text
 
            ' calculate standby time
            Dim standbyTime As String = intTotalHours - intWorkTime
 
            'check to see if value is positive
            If standbyTime < 0 Then
                Me.LabelNegativeValue.Text = "The Standby Time can not be less than '0', Please check your date/time values"
                Exit Sub
            End If
 
            Me.LabelTotalTime.Text = intTotalHours & " Total Hours"
            Me.LabelStandBy.Text = standbyTime.ToString & " Standby Time"
            Me.LabelWorkTime.Text = intWorkTime.ToString & " Work Time"
            Me.LabelNoEndDate.Text = ""
            Me.LabelNoStartDate.Text = ""
        End If
 
    End Sub

Open in new window

0

Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

New Relic: Our company recently started researching several products to figure out what were the best ways for us to increase our web page speed and to quickly identify performance problems that we may be having. One of the products we evaluated wa…
Since upgrading to Office 2013 or higher installing the Smart Indenter addin will fail. This article will explain how to install it so it will work regardless of the Office version installed.
This video teaches viewers how to create their own website using cPanel and Wordpress. Tutorial walks users through how to set up their own domain name from tools like Domain Registrar, Hosting Account, and Wordpress. More specifically, the order in…
This lesson covers basic error handling code in Microsoft Excel using VBA. This is the first lesson in a 3-part series that uses code to loop through an Excel spreadsheet in VBA and then fix errors, taking advantage of error handling code. This l…

685 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question