From 96c937bb0cef32a88b4881941c86ac388afa7486 Mon Sep 17 00:00:00 2001 From: Peter Date: Wed, 21 Aug 2019 14:05:28 -0400 Subject: [PATCH 1/3] Added exporting dividends with the --dividends flag --- csv-export.py | 93 +++++++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 87 insertions(+), 6 deletions(-) diff --git a/csv-export.py b/csv-export.py index b8b214a..21c09bb 100644 --- a/csv-export.py +++ b/csv-export.py @@ -22,6 +22,8 @@ '--mfa_code', help='your Robinhood mfa_code') parser.add_argument( '--profit', action='store_true', help='calculate profit for each sale') +parser.add_argument( + '--dividends', action='store_true', help='export dividend payments') args = parser.parse_args() username = args.username password = args.password @@ -170,12 +172,91 @@ if filename == '': filename = "robinhood.csv" -# save the CSV -try: - with open(filename, "w+") as outfile: - outfile.write(csv) -except IOError: - print("Oops. Unable to write file to ", filename) + +if args.dividends: + fields=collections.defaultdict(dict) + dividend_count = 0 + queued_dividends = 0 + + # fetch order history and related metadata from the Robinhood API + dividends = robinhood.get_endpoint('dividends') + + + paginated = True + page = 0 + while paginated: + for i, dividend in enumerate(dividends['results']): + symbol = cached_instruments.get(dividend['instrument'], False) + if not symbol: + symbol = robinhood.get_custom_endpoint(dividend['instrument'])['symbol'] + cached_instruments[dividend['instrument']] = symbol + + fields[i + (page * 100)]['symbol'] = symbol + + for key, value in enumerate(dividend): + if value != "executions": + fields[i + (page * 100)][value] = dividend[value] + + fields[i + (page * 100)]['execution_state'] = order['state'] + + if dividend['state'] == "pending": + queued_dividends += 1 + elif dividend['state'] == "paid": + dividend_count += 1 + # paginate + if dividends['next'] is not None: + page = page + 1 + orders = robinhood.get_custom_endpoint(str(dividends['next'])) + else: + paginated = False + + # for i in fields: + # print fields[i] + # print "-------" + + # check we have trade data to export + if dividend_count > 0 or queued_dividends > 0: + print("%d queued dividend%s and %d executed dividend%s found in your account." % + (queued_dividends, "s" [queued_count == 1:], dividend_count, + "s" [trade_count == 1:])) + # print str(queued_count) + " queded trade(s) and " + str(trade_count) + " executed trade(s) found in your account." + else: + print("No dividend history found in your account.") + quit() + + # CSV headers + keys = fields[0].keys() + keys = sorted(keys) + csv = ','.join(keys) + "\n" + + # CSV rows + for row in fields: + for idx, key in enumerate(keys): + if (idx > 0): + csv += "," + try: + csv += str(fields[row][key]) + except: + csv += "" + + csv += "\n" + + # choose a filename to save to + print("Choose a filename or press enter to save to `dividends.csv`:") + try: + input = raw_input + except NameError: + pass + filename = input().strip() + if filename == '': + filename = "dividends.csv" + + # save the CSV + try: + with open(filename, "w+") as outfile: + outfile.write(csv) + except IOError: + print("Oops. Unable to write file to ", filename) if args.profit: profit_csv = profit_extractor(csv, filename) From 79e8df7073f706f76c1537c5b1b3335d737e22f6 Mon Sep 17 00:00:00 2001 From: Peter Date: Wed, 21 Aug 2019 14:08:32 -0400 Subject: [PATCH 2/3] Fixed accidental deletion of order output --- csv-export.py | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/csv-export.py b/csv-export.py index 21c09bb..02a3c2a 100644 --- a/csv-export.py +++ b/csv-export.py @@ -172,6 +172,12 @@ if filename == '': filename = "robinhood.csv" +try: + with open(filename, "w+") as outfile: + otufile.write(csv) +except IOError: + print("Oops. Unable to write file to ", filename) + if args.dividends: fields=collections.defaultdict(dict) From 36dd647469076c35c39108a8f2d42a0039b1c107 Mon Sep 17 00:00:00 2001 From: Peter Date: Wed, 21 Aug 2019 14:10:05 -0400 Subject: [PATCH 3/3] Fixed Typo --- csv-export.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/csv-export.py b/csv-export.py index 02a3c2a..606e373 100644 --- a/csv-export.py +++ b/csv-export.py @@ -174,7 +174,7 @@ try: with open(filename, "w+") as outfile: - otufile.write(csv) + outfile.write(csv) except IOError: print("Oops. Unable to write file to ", filename)