forked from rtucker/gnucash-importers
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtransactions-paypal.py
executable file
·108 lines (83 loc) · 3.83 KB
/
transactions-paypal.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#!/usr/bin/python
TESTING=False
import csv
import sys
from decimal import Decimal
from gnucashlib import Gnucash
if len(sys.argv) != 2:
print "usage: %s infile" % sys.argv[0]
sys.exit(1)
if TESTING:
filename = "/home/rtucker/Dropbox/Projects/Interlock/gnucash-test/interlock-rochester-test.gnucash"
else:
filename = "/home/rtucker/Dropbox/Projects/Interlock/gnucash-prod/interlock-rochester.gnucash"
with Gnucash(filename) as gc:
from_acct = gc.account("Assets:Current Assets:PayPal")
fee_acct = gc.account("Expenses:Bank Service Charge")
posted_acct = gc.account("Assets:Accounts Receivable")
# Read in CSV from PayPal
incsv = csv.DictReader(open(sys.argv[1], 'rb'), skipinitialspace=True)
for row in incsv:
month, day, year = [int(f) for f in row['Date'].split('/')]
date = '%04d-%02d-%02d' % (year, month, day)
num = row['Transaction ID']
description = row['Name']
notes = row['Type']
net = Decimal(row['Net'].replace(',', ''))
gross = -Decimal(row['Gross'].replace(',', ''))
fee = -Decimal(row['Fee'].replace(',', ''))
# Guess the account
if net < 0.00:
# debit
account = 'Expenses:Miscellaneous'
if row['Name'] == 'Bank Account':
account = 'Assets:Current Assets:Checking Account'
description = "Transfer from PayPal to Checking Account"
if row['Name'] == 'dennis MAGUIRE':
account = 'Expenses:Rent'
else:
# credit
account = 'Income:Other Income'
if row['Item ID'].startswith('INV'):
account = 'Income:Member Dues'
notes += ' (%s)' % row['Item ID']
elif "Donation" in row["Type"]:
account = 'Income:Donations'
elif "Meraki" in row["Name"]:
account = 'Income:Meraki'
to_acct = gc.account(account)
if row['Item ID'] is not "":
invoice = gc.InvoiceLookupByID(row['Item ID'])
else:
invoice = None
if not gc.seen(from_acct, num):
print "New Transaction:", num, date, description, gross, invoice.GetID() if invoice is not None else 'N/A', account
newtx = gc.NewTransaction()
newtx.SetNum(num)
newtx.SetDate(day, month, year)
newtx.SetDescription(description)
newtx.SetNotes(notes)
s1 = gc.NewSplit(newtx, from_acct, net)
s2 = gc.NewSplit(newtx, to_acct, gross)
if invoice is not None:
# The invoice payment handler is a little bit destructive.
# So, we do it here before we apply the fee, otherwise
# an imbalance occurs.
gc.PayInvoiceWithTransaction(invoice, newtx, from_acct, gross, "Paid via Invoiceable.com -> PayPal", num)
print "--> Applied to invoice:", invoice.GetID()
print " Customer Balance:", invoice.GetOwner().GetBalanceInCurrency(gc.commods['USD'])
elif account is 'Income:Other Income' and row['From Email Address'] != "":
# Try to apply it to a customer
customer = gc.GetCustomerByEmail(row['From Email Address'])
if customer is not None:
gc.ApplyPaymentToCustomer(customer, newtx, posted_acct, from_acct, gross, "Paid via PayPal", num)
print "--> Applied to customer:", customer.GetName()
print " Customer Balance:", customer.GetBalanceInCurrency(gc.commods['USD'])
s3 = gc.NewSplit(newtx, fee_acct, fee)
if gc.TransactionReadyToCommit(newtx):
newtx.CommitEdit()
else:
print "ROLLBACK: IMBALANCE"
newtx.RollbackEdit()
break
gc.save()