?
Solved

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

Posted on 2008-10-15
4
Medium Priority
?
497 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
4 Comments
 
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

Get 15 Days FREE Full-Featured Trial

Benefit from a mission critical IT monitoring with Monitis Premium or get it FREE for your entry level monitoring needs.
-Over 200,000 users
-More than 300,000 websites monitored
-Used in 197 countries
-Recommended by 98% of users

Question has a verified solution.

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

A publishing tool, a Version Control System, or a Collaboration Platform! These can be some of the defining words for the two very famous web-hosting Git repositories: Bitbucket and Github. Git is widely used amongst the programmers and developers f…
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…
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…
Suggested Courses
Course of the Month13 days, 2 hours left to enroll

777 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