NAME
Finance::Budget - A module for helping you predict the effectiveness of your budget.
SYNOPSIS
use Finance::Budget;
my $budget = Finance::Budget->new(
{ days => 365,
opening_balance => 123.01,
transaction_types => [
{ category => 'PAYCHECK',
amount => 1234.56,
event => '0:0:2*4:0:0:0', # every second Thursday
},
{ category => 'Visa',
amount => -100.00,
event => '0:1*0:0:0:0:0', # first of every month
},
{ category => 'Cox',
amount => -101.01,
event => '0:1*0:15:0:0:0', # fifteenth of every month
},
{ category => 'Mortgage',
amount => -1000.10,
event => '0:1*0:0:0:0:0',
},
{ category => 'Water',
amount => -150.00,
event => '0:3*0:1:0:0:0', # first of every third month
},
],
exceptions => [
{ category => 'Visa',
amount => 0.00,
date => '12/20/2016',
},
{ category => 'Cox',
amount => 0.00,
date => '01/01/2017',
},
{ category => 'Mortgage',
amount => 0.00,
date => '01/01/2017',
},
],
recent_history => [
qq{"Date","No.","Description","Debit","Credit"},
qq{"12/28/2016","","ACH Trans - Big Plastic","100.00",""},
qq{"12/27/2016","","ACH Trans - COX CABLE","101.01",""},
qq{"12/26/2016","","ACH Trans - US BANK MTG","1000.10",""},
qq{"12/01/2016","","ACH Trans - Waters R Us","150.00",""},
qq{"12/22/2016","","Deposit - Employer Inc","","1234.56"},
],
categorizer => {
'PAYCHECK' => [
qr{ employer \s inc }xmsi
],
'Visa' => [
qr{ big \s plastic }xmsi
],
'Cox' => [
qr{ cox \s cable }xmsi,
qr{ cox \s communications }xmsi,
],
'Mortgage' => [
qr{ us \s bank \s mtg }xmsi
],
'Water' => [
qr{ waters \s are \s us }xmsi
]
}
}
);
printf " Opening Balance: % 28s\n",
$budget->opening_balance();
while ( my $transaction = $budget->next() )
{
print "$transaction\n";
}
my $chokepoints = $budget->get_chokepoints();
printf "\n Eye of the needle:\n%s\n\n",
$chokepoints->eye();
printf " Chokepoints:\n";
while ( my $point = $chokepoints->next() )
{
print "$point\n";
}
DESCRIPTION
This module consumes information about your budget planning and then creates a series of transactions to project what lays ahead.
This can be useful when considering taking on a new car payment or making a big purchase. For example, spending $300 today might have unexpected ramifications 90 days from now. This can also be handy in fine tuning your budget to ensure that it is sustainable.
Check out budget.pl in the demo directory of this project.
CONSTRUCTOR
PARAMETERS
- days
-
The number of days to project into the future.
- date_format
-
The format that the transactions will use on stringafication. The default format is '%m/%d/%Y'.
- markup_callback
-
This is a code reference that gets invoked for each transaction stringafication event. You can use this to format the output any way you like.
The callback receives as the first argument a hash ref like:
{ date_str => '...', title => '...', amount => '$...', balance_str => '...', string => '...', date => <Date::Manip::Date object>, category => '...', cents => 0, }
- opening_balance
-
The opening blanace, in dollars, of your checking account.
- transaction_types
-
This is a list of transaction type descriptor hashes. Each descriptor has three attributes:
{ category => 'Foobar', # category name amount => -1.00, # dollar amount -/+ recurrence => '0:1*0:0:0:0:0', # Date::Manip::Recur string }
This field also accepts a data filename which will be read using the Perl do() function.
- exceptions
-
Use this to define one-off exceptions. For example, your electric utilty bill might generally be $100.00. But you happen to know the next payment will be exactly $87.42.
So, you can define an exception:
{ category => 'Electric', amount => -87.42, date => '02/01/2017', # parsable by Date::Manip::Date }
This field also accepts a data filename which will be read using the Perl do() function.
- recent_history
-
This is a list of CSV lines that are scanned for the most recent occurrence date for each transaction type. These dates are important because they are the 'base date' for each recurring transaction. (See Date::Manip::Recur)
Each CSV line is expected to have a 'date' and a 'description' field as given by the first CSV line. This happens to be exactly what my financial institution provides when I download a CSV file from my online banking site.
This field also accepts a CSV filename which will be slurped into memory.
- categorizer
-
This option accepts a hash of category names mapped to one of two things:
An array ref of regexes. Each regex will be applied to the 'description' in the recent history data. When a match is made that category is applied.
A code ref for a function that returns true if the 'description' applies to this category.
METHODS
opening_balance()
Returns a stringified version of the opening balance (supplied in the constructor).
next()
Get the next transaction.
get_chokepoints()
Returns a chokepoint iterator.
TRANSACTIONS
Each transaction represents one event in your budget lifespan.
You'll probably just be satisified to print each "$transaction" in its stringified form, which uses the markup callback you provide.
The transaction object also offers some getter methods.
CHOKEPOINTS
The chokepoints are the balance minima between the significant expenses and the significant income events. You might be interested in iterating through these to see where you're going to run into trouble.
eye()
This is the "eye" as in threading the needle -- the smallest of the chokepoints.
next()
Get the next chokepoint.
SEE ALSO
Date::Manip::Recur
Text::CSV
AUTHOR
Dylan Doxey, <dylan@cpan.org>
COPYRIGHT AND LICENSE
Copyright (C) 2017 by Dylan Doxey
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.22.1 or, at your option, any later version of Perl 5 you may have available.