Giter Site home page Giter Site logo

mustaching's Introduction

Mustaching

https://img.shields.io/badge/launch-binder-579ACA.svg?logo=

A tiny Python 3.9+ library inspired by Mr. Money Mustache to summarize and plot personal finance data given in a CSV file of transactions. Uses Pandas and Plotly to do most of the work.

chart

Smacks of plain text accounting but is limited to single-entry transactions and focuses only on income and expenses. For full-featured double-entry bookkeeping in Python, use a different library, such as beancount.

Installation

Create a Python 3.9+ virtual environment and run poetry add mustaching.

Usage

Play with the Jupyter notebook at notebooks/examples.ipynb. You can even do so online by clicking the Binder badge above. Using Binder you can also upload your own transaction data into the notebook, but consider first Binder's warning about private data.

Your CSV of transactions should contain at least the following columns

  • date: string; something consistent and recognizable by Pandas, e.g 2016-11-26
  • amount: float; amount of transaction; positive or negative, indicating an income or expense, respectively
  • description (optional): string; description of transaction, e.g. 'dandelion and burdock tea'
  • category (optional): string; categorization of description, e.g. 'healthcare'
  • comment (optional): string; comment on transaction, e.g. 'a gram of prevention is worth 16 grams of cure'

The business logic can be found in mustaching/main.py

Documentation

At araichev.github.io/mustaching_docs/.

Notes

  • Development status: Alpha
  • This project uses semantic versioning

Authors

  • Alex Raichev, 2016-11

Changes

4.0.3, 2023-11-04

  • Updated dependencies.
  • Added Github action for testing.

4.0.2, 2022-02-27

  • Updated dependencies, removing version caps.

4.0.1, 2021-10-21

  • In summarize(), dropped unused categories after slicing to the given date range.

4.0.0, 2021-10-20

  • Upgraded to Python 3.9.
  • Major refactor of summarize() and plot() functions.
  • Replaced Python Highcharts with Plotly.

3.1.3, 2021-01-23

  • Used Pandera for data validation.
  • Tweaked chart colors.

3.1.2, 2020-09-06

  • Upgraded to Python 3.8.

3.1.1, 2019-04-03

  • Switched to Poetry.
  • Published docs using publish-sphinx-docs.
  • Published on PyPi.
  • Dropped unused categories in summarize().

3.1.0, 2018-03-31

  • Changed the columns output by the function summarize

3.0.0, 2018-01-01

  • Renamed the function build_sample_transactions to create_transactions
  • Added more columns to the output of the function summarize
  • Switched from using 'credit' and 'debit' to 'income' and 'expense', because i find that clearer

2.2.1, 2017-10-14

  • In function summarize, changed weekly and daily averages calculations to use credit - debit. Also changed default sort order of DataFrame output.

2.2.0, 2017-09-25

  • Changed function summarize to split savings rate by category and to include weekly and daily averages when no frequency is given
  • Fixed an edge-case division-by-zero bug in function summarize

2.1.0, 2017-05-07

  • Fixed a bug in function insert_repeating that lost the categorical dtype
  • Added optional slicing by date in function summarize

2.0.1, 2017-04-26

  • Fixed the bug where setup.py could not find the license file

2.0.0, 2017-04-25

  • Removed budget_and_freq option, because i don't need that extra complexity
  • Calculated spending rate
  • Added function insert_repeating to avoid having to record repeating transactions in my personal spendings
  • Prepared for PyPi

1.2.1, 2017-03-01

  • Fixed README and ipynb/examples.ipynb

1.2.0, 2017-03-01

  • Lowercased category names and values when reading transactions
  • Added percentages to bar chart stacks when splitting by categories
  • Sorted categories from highest to lowest values in bar chart stacks
  • Changed name to 'mustaching' and restructured directories
  • Wrote automated tests

1.1.0, 2016-12-13

  • Made function read_ransactions infer column names a little
  • Made funnction summarize always create 'period_budget' column and fill it with NaNs if no budget given

1.0.0, 2016-12-10

  • Changed summary columns to 'credit', 'expense', and 'balance'
  • Plotted balance as a cumulative sum line series

0.1.1, 2016-11-21

Fixed date labels and off-by-1-day error in time grouping

0.1.0, 2016-11-18

First release

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.