Solved

Function to return last date of quarter

Posted on 2013-11-23
2
478 Views
Last Modified: 2013-11-23
Hi,

Does anybody have a function that returns the last date of a quarter based on a given date.

Input: 1-1-2013 -> Return: 31-3-2013
Input: 15-2-2013 -> Return: 31-3-2013
Input: 7-6-2013 -> Return: 30-6-2013
etc.
0
Comment
Question by:Delphiwizard
2 Comments
 
LVL 31

Accepted Solution

by:
Marco Gasi earned 500 total points
ID: 39671883
You can use this:

function GetLastDayOfQuarter(DT: TDateTime): TDateTime;
begin
  Result := Now();
  if  InRange(MonthOf(DT), 1, 3) then
    Result := EndOfAMonth(YearOf(DT), 3)
  else
  if  InRange(MonthOf(DT), 4, 6) then
    Result := EndOfAMonth(YearOf(DT), 6)
  else
  if  InRange(MonthOf(DT), 7, 9) then
    Result := EndOfAMonth(YearOf(DT), 9)
  else
  if  InRange(MonthOf(DT), 10, 12) then
    Result := EndOfAMonth(YearOf(DT), 12);
end;

Open in new window


This is the test program:

Form:
object Form1: TForm1
  Left = 0
  Top = 0
  Caption = 'Form1'
  ClientHeight = 219
  ClientWidth = 340
  Color = clBtnFace
  Font.Charset = DEFAULT_CHARSET
  Font.Color = clWindowText
  Font.Height = -11
  Font.Name = 'Tahoma'
  Font.Style = []
  OldCreateOrder = False
  OnCreate = FormCreate
  PixelsPerInch = 96
  TextHeight = 13
  object Label1: TLabel
    Left = 104
    Top = 48
    Width = 140
    Height = 33
    Caption = '00/00/0000'
    Font.Charset = DEFAULT_CHARSET
    Font.Color = clWindowText
    Font.Height = -27
    Font.Name = 'Tahoma'
    Font.Style = []
    ParentFont = False
  end
  object DateTimePicker1: TDateTimePicker
    Left = 80
    Top = 128
    Width = 186
    Height = 21
    Date = 41601.925650833340000000
    Time = 41601.925650833340000000
    TabOrder = 0
    OnChange = DateTimePicker1Change
  end
end

Open in new window


Unit:
unit Unit1;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.ComCtrls, System.DateUtils, System.Math,
  Vcl.StdCtrls;

type
  TForm1 = class(TForm)
    DateTimePicker1: TDateTimePicker;
    Label1: TLabel;
    procedure DateTimePicker1Change(Sender: TObject);
    procedure FormCreate(Sender: TObject);
  private
  public
    { Public declarations }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

function GetLastDayOfQuarter(DT: TDateTime): TDateTime;
begin
  if  InRange(MonthOf(DT), 1, 3) then
    Result := EndOfAMonth(YearOf(DT), 3)
  else
  if  InRange(MonthOf(DT), 4, 6) then
    Result := EndOfAMonth(YearOf(DT), 6)
  else
  if  InRange(MonthOf(DT), 7, 9) then
    Result := EndOfAMonth(YearOf(DT), 9)
  else
  if  InRange(MonthOf(DT), 10, 12) then
    Result := EndOfAMonth(YearOf(DT), 12);
end;

procedure TForm1.DateTimePicker1Change(Sender: TObject);
begin
  Label1.Caption := DateToStr(GetLastDayOfQuarter(DateTimePicker1.DateTime));
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
  Label1.Caption := DateToStr(Now());
end;

end.

Open in new window

0
 

Author Closing Comment

by:Delphiwizard
ID: 39672212
Excellent, thank you very much.
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Run video youtube webbrowse 10 74
delphi parse string to params 3 158
Delphi: ForceDirectory plain function 7 50
Slow Restore if incremental backups using RDiff.exe 4 39
Have you ever had your Delphi form/application just hanging while waiting for data to load? This is the article to read if you want to learn some things about adding threads for data loading in the background. First, I'll setup a general applica…
In my programming career I have only very rarely run into situations where operator overloading would be of any use in my work.  Normally those situations involved math with either overly large numbers (hundreds of thousands of digits or accuracy re…
In a recent question (https://www.experts-exchange.com/questions/29004105/Run-AutoHotkey-script-directly-from-Notepad.html) here at Experts Exchange, a member asked how to run an AutoHotkey script (.AHK) directly from Notepad++ (aka NPP). This video…

696 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