Browse Source

Added the option to export your transactions to a CSV file

283
Maran 12 years ago
parent
commit
108da45e53
  1. 42
      lib/gui_lite.py

42
lib/gui_lite.py

@ -28,7 +28,10 @@ import wallet
import webbrowser import webbrowser
import history_widget import history_widget
import util import util
import csv
import datetime
from wallet import format_satoshis
import gui_qt import gui_qt
import shutil import shutil
@ -254,6 +257,9 @@ class MiniWindow(QDialog):
backup_wallet = extra_menu.addAction( _("&Create wallet backup")) backup_wallet = extra_menu.addAction( _("&Create wallet backup"))
backup_wallet.triggered.connect(self.backup_wallet) backup_wallet.triggered.connect(self.backup_wallet)
export_csv = extra_menu.addAction( _("&Export transactions to CSV") )
export_csv.triggered.connect(self.actuator.csv_transaction)
expert_gui = view_menu.addAction(_("&Classic GUI")) expert_gui = view_menu.addAction(_("&Classic GUI"))
expert_gui.triggered.connect(expand_callback) expert_gui.triggered.connect(expand_callback)
themes_menu = view_menu.addMenu(_("&Themes")) themes_menu = view_menu.addMenu(_("&Themes"))
@ -732,6 +738,42 @@ class MiniActuator:
w.exec_() w.exec_()
w.destroy() w.destroy()
def csv_transaction(self):
try:
fileName = QFileDialog.getSaveFileName(QWidget(), 'Select file to export your wallet transactions to', os.path.expanduser('~/'), "*.csv")
if fileName:
with open(fileName, "w+") as csvfile:
transaction = csv.writer(csvfile)
transaction.writerow(["transaction_hash","label", "confirmations", "value", "fee", "balance", "timestamp"])
for item in self.wallet.get_tx_history():
tx_hash, confirmations, is_mine, value, fee, balance, timestamp = item
if confirmations:
try:
time_string = datetime.datetime.fromtimestamp( timestamp).isoformat(' ')[:-3]
except [RuntimeError, TypeError, NameError] as reason:
print reason
time_string = "unknown"
else:
time_string = "pending"
if value is not None:
value_string = format_satoshis(value, True, self.wallet.num_zeros)
else:
value_string = '--'
if fee is not None:
fee_string = format_satoshis(fee, True, self.wallet.num_zeros)
else:
fee_string = '0'
if tx_hash:
label, is_default_label = self.wallet.get_label(tx_hash)
balance_string = format_satoshis(balance, False, self.wallet.num_zeros)
transaction.writerow([tx_hash, label, confirmations, value_string, fee_string, balance_string, time_string])
QMessageBox.information(None,"CSV Export created", "Your CSV export has been succesfully created.")
except (IOError, os.error), reason:
QMessageBox.critical(None,"Unable to create csv", "Electrum was unable to produce a transaction export.\n" + str(reason))
def send(self, address, amount, parent_window): def send(self, address, amount, parent_window):
"""Send bitcoins to the target address.""" """Send bitcoins to the target address."""
dest_address = self.fetch_destination(address) dest_address = self.fetch_destination(address)

Loading…
Cancel
Save