Solved

Date calculation question

Posted on 2013-01-24
7
288 Views
Last Modified: 2013-01-24
On a form I have a field named "txtAck_Date".  Also on the form I have a field named "txtTotalLTdays" which is a number field.  Then there is a 3rd field on the form named "txtProdDate".

I need the field "txtProdDate" to be a calculated field.  When the user enters a date in "txtAck_Date" then "txtProdDate" has to be "txtAck_Date" MINUS the days in "txtTotalLTdays" BUT NOT INCLUDING WEEKENDS (Saturdays or Sundays).

For example, using February of this year, if the user enters 2/21/13 in "txtAck_Date" I need to have "txtProdDate" back up by 20 days if "txtTotalLtDays" is 20.  Therefore "txtProdDate" would be automatically calculated to be 1/24/13.

I can't figure out what the afterupdate event code would be for "txtAck_Date".
0
Comment
Question by:SteveL13
  • 4
  • 3
7 Comments
 
LVL 61

Expert Comment

by:mbizup
ID: 38815327
try this:

txtProdDate =  DateAdd( "w", -20 , txtAck_Date)
0
 

Author Comment

by:SteveL13
ID: 38815417
I'm sorry.  One thing all should know is that "txtTotalLtDays" is also a calculated field.  I used 20 as an example but it could be any number.  

Using:

txtProdDate =  DateAdd( "w", -20 , txtAck_Date)

didn't work though.  When I enter 2/21/13 in the "txtShipDate" field 2/1/13 populated "txtProdDate" and it should be 1/24/13 becuase it has to NOT include weekend days.
0
 

Author Comment

by:SteveL13
ID: 38815637
I tried:

 Me.txtProdDate = DateAdd("w", -Val(Me.txtTotalLTdays), Me.txtAck_Date)

And I still get 2/1/13 when I enter 2/21/13 instead of getting 1/24/13.

??
0
Enabling OSINT in Activity Based Intelligence

Activity based intelligence (ABI) requires access to all available sources of data. Recorded Future allows analysts to observe structured data on the open, deep, and dark web.

 

Author Comment

by:SteveL13
ID: 38815803
I meant to type:

I tried:

 Me.txtProdDate = DateAdd("w", -Val(Me.txtTotalLTdays), Me.txtShipDate)

And I still get 2/1/13 when I enter 2/21/13 instead of getting 1/24/13.

??
0
 
LVL 61

Accepted Solution

by:
mbizup earned 500 total points
ID: 38815887
Okay -- I think you'll have to use a custom function.

Try placing this in a separate module:

Function DateDiffNoWeekends(dt As Date, intNumDays As Integer) As Date
    Dim I As Integer
    Dim dtNew As Date
    I = 0
    dtNew = dt
    Do Until I = intNumDays
        dtNew = dtNew - 1
        Do Until Weekday(dtNew) <> 7 And Weekday(dtNew) <> 1
            dtNew = dtNew - 1
        Loop
        I = I + 1
    Loop
    DateDiffNoWeekends = dtNew
    
End Function

Open in new window


And call it from your after update event like this:

 Me.txtProdDate = DateDiffNoWeekends( Me.txtShipDate,   Me.txtTotalLTdays)

Open in new window



(Im assuming that you will be passing a positive number in txtTotalLTdays)
0
 

Author Comment

by:SteveL13
ID: 38815985
To mbizup:

A perfect work of art!  Thank you.
0
 
LVL 61

Expert Comment

by:mbizup
ID: 38816015
Thanks, Steve!  Glad that helped out :-)

The next reasonable 'step' in these questions is very often "how do I exclude holidays?".

That block of code is a starting point... and if you needed to exclude holidays, you'd have to create a holiday table and use DLookups from that table or some other method within the loop to skip over dates that are included in your holiday table.
0

Featured Post

Find Ransomware Secrets With All-Source Analysis

Ransomware has become a major concern for organizations; its prevalence has grown due to past successes achieved by threat actors. While each ransomware variant is different, we’ve seen some common tactics and trends used among the authors of the malware.

Join & Write a Comment

Suggested Solutions

Introduction When developing Access applications, often we need to know whether an object exists.  This article presents a quick and reliable routine to determine if an object exists without that object being opened. If you wanted to inspect/ite…
Experts-Exchange is a great place to come for help with solutions for your database issues, and many problems are resolved within minutes of being posted.  Others take a little more time and effort and often providing a sample database is very helpf…
Familiarize people with the process of utilizing SQL Server views from within Microsoft Access. Microsoft Access is a very powerful client/server development tool. One of the SQL Server objects that you can interact with from within Microsoft Access…
Familiarize people with the process of retrieving data from SQL Server using an Access pass-thru query. Microsoft Access is a very powerful client/server development tool. One of the ways that you can retrieve data from a SQL Server is by using a pa…

762 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

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now