Skip to content

A CLI tool built using Python for calculating your capital gains and adjusted cost base (ACB) for Canadian taxes.

License

Notifications You must be signed in to change notification settings

EmilMaric/cad-capital-gains

Folders and files

NameName
Last commit message
Last commit date

Latest commit

9f88119 · Sep 7, 2020

History

22 Commits
Sep 7, 2020
Sep 7, 2020
Sep 2, 2020
Sep 3, 2020
Sep 7, 2020
May 18, 2020
Sep 7, 2020
Sep 2, 2020
Sep 2, 2020
Sep 7, 2020
Sep 2, 2020

Repository files navigation

Canadian Capital Gains CLI Tool

Build Status codecov

Calculating your capital gains and tracking your adjusted cost base (ACB) manually, or using an Excel document, often proves to be a laborious process. This CLI tool calculates your capital gains and ACB for you, and just requires a CSV file with basic information about your transactions. The idea with this tool is that you are able to more or less cut-and-copy the output that it genarates and copy it into whatever tax filing software you end up using.

Noteable features:

  • Supports transactions with multiple different stock tickers in the same CSV file, and outputs them in separate tables.
  • Currently supports transactions done in both USD and CAD. For USD transactions, the daily exchange rate will be automatically fetched from the Bank of Canada.
  • Will automatically apply superficial capital loss rules when calculating your capital gains and ACB. This tool only supports full superficial capital losses, and does not support partial superficial losses. In sales with a superficial capital loss, the capital loss will be carried forward as perscribed by the CRA. A sale with a capital loss will be treated as superficial if it satisifies the following:
    • Shares with the same ticker were bought in the 61 day window (30 days before or 30 days after the sale)
    • There is a non-zero balance of shares sharing the same ticker at the end of the 61 day window (30 days after the sale)
  • Outputs the running adjusted cost base (ACB) for every transaction with a non-superficial capital gain/loss

Installation

# To get the latest release
pip install cad-capgains

CSV File Requirements

To start, create a CSV file that will contain all of your transactions. In the CSV file, each line will represent a BUY or SELL transaction. Your transactions must be in order, with the oldest transactions coming first, followed by newer transactions coming later. The format is as follows:

<yyyy-mm-dd>,<transaction_description>,<stock_ticker>,<action(BUY/SELL)>,<quantity>,<price>,<commission>,<currency>

Here is a sample CSV file:

# sample.csv
2017-2-15,ESPP PURCHASE,GOOG,BUY,100,50.00,10.00,USD
2017-5-20,RSU VEST,GOOG,SELL,50,45.00,0.00,CAD

NOTE: This tool only supports calculating ACB and capital gains with transactions dating from May 1, 2007 and onwards.

Usage

To show the CSV file in a nice tabular format you can run:

$ capgains show sample.csv
+------------+--------------------+----------+----------+-------+---------+--------------+------------+
| date       | transaction_type   | ticker   | action   |   qty |   price |   commission |   currency |
|------------+--------------------+----------+----------+-------+---------+--------------+------------|
| 2017-02-15 | ESPP PURCHASE      | GOOG     | BUY      |   100 |   50.00 |        10.00 |        USD |
| 2017-05-20 | RSU VEST           | GOOG     | SELL     |    50 |   45.00 |         0.00 |        CAD |
+------------+--------------------+----------+----------+-------+---------+--------------+------------+

To calculate the capital gains you can run:

$ capgains calc sample.csv 2017
GOOG-2017
[Total Gains = -1,028.54]
+------------+--------------------+----------+----------+-------+---------+--------------+------------+-----------------+------------+----------------+-------------+----------+
| date       | transaction_type   | ticker   | action   |   qty |   price |   commission |   currency |   share_balance |   proceeds |   capital_gain |   acb_delta |      acb |
|------------+--------------------+----------+----------+-------+---------+--------------+------------+-----------------+------------+----------------+-------------+----------|
| 2017-05-20 | RSU VEST           | GOOG     | SELL     |    50 |   45.00 |         0.00 |        CAD |              50 |   2,250.00 |      -1,028.54 |   -3,278.54 | 3,278.54 |
+------------+--------------------+----------+----------+-------+---------+--------------+------------+-----------------+------------+----------------+-------------+----------+

Your CSV file can contain transactions spanning across multiple different tickers. You can filter the above commands by running the following:

$ capgains calc sample.csv 2017 -t GOOG
...

$ capgains show sample.csv -t GOOG
...

For additional commands and options, run one of the following:

$ capgains --help

$ capgains <command> --help

About

A CLI tool built using Python for calculating your capital gains and adjusted cost base (ACB) for Canadian taxes.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages