mirror of
https://github.com/Gnucash/gnucash.git
synced 2025-02-25 18:55:30 -06:00
This patch changes the example script to reflect the capability of reading all namespaces. Patch provided by Christoph Holtermann. git-svn-id: svn+ssh://svn.gnucash.org/repo/gnucash/trunk@19954 57a11ea4-9604-0410-9ed3-97b8803252fd
85 lines
3.1 KiB
Python
Executable File
85 lines
3.1 KiB
Python
Executable File
#!/usr/bin/env python
|
|
# Another test file for price database stuff
|
|
# To update the price database call
|
|
# $PATH/gnucash --add-price-quotes $PATHTOFILE
|
|
# before running this.
|
|
# Adding to a calling bash script would be better
|
|
# Although calling it from here would be even better!
|
|
# OR: export PYTHONPATH=$HOME/progs/lib/python2.6/site-packages
|
|
# Then: gnucash-env ipython
|
|
# The account file is not saved but always use a disposable copy.
|
|
# Thanks for contributions by Christoph Holtermann
|
|
|
|
import gnucash
|
|
from gnucash.gnucash_core_c import gnc_pricedb_get_db, gnc_pricedb_get_prices, gnc_pricedb_lookup_latest,gnc_pricedb_print_contents
|
|
from gnucash.gnucash_core import *
|
|
|
|
# -------------------------------------------
|
|
# Configuration options can be changed here :
|
|
|
|
cur_mnemonic="EUR" # Currency that prices are shown in. Possibilities include "EUR","GBP",...
|
|
namespace_name = "" # If no namespace_name is set, all namespaces will be shown
|
|
show_prices = True # If True, all prices for commodity are shown
|
|
commodity_fullname = "" # If no name is given, all commoditys in namespace will be shown
|
|
FILE = "PATH_TO_YOUR_TEST_FILE" # File is not saved but use a copy anyway
|
|
url = "xml://"+FILE
|
|
|
|
# Configuration end
|
|
# -------------------------------------------
|
|
|
|
session = Session(url, True, False, False)
|
|
|
|
root = session.book.get_root_account()
|
|
book = session.book
|
|
pdb = book.get_price_db()
|
|
comm_table = book.get_table()
|
|
|
|
cur = comm_table.lookup("CURRENCY", cur_mnemonic)
|
|
cur_name = cur.get_fullname()
|
|
|
|
if namespace_name: # Show single namespace
|
|
namespaces=[]
|
|
namespace=gnucash.gnucash_core_c.gnc_commodity_table_find_namespace(comm_table.instance,"EUREX")
|
|
else: # Show all namespaces
|
|
namespaces=comm_table.get_namespaces_list()
|
|
|
|
for namespace in namespaces:
|
|
namespace_name=gnucash.gnucash_core_c.gnc_commodity_namespace_get_name(namespace)
|
|
|
|
# Get a list of all commodities in namespace
|
|
commodities=comm_table.get_commodities(namespace_name)
|
|
|
|
if not commodities:
|
|
print "No commodity in namespace "+namespace_name+"."
|
|
else:
|
|
if commodity_fullname:
|
|
print "Searching commodity '"+commodity_fullname+"' in namespace "+namespace_name
|
|
else:
|
|
print "Commoditys in namespace "+namespace_name+":"
|
|
|
|
for i in range(len(commodities)):
|
|
c=gnucash.GncCommodity(instance=commodities[i])
|
|
commodities[i]=c
|
|
|
|
c_fullname = c.get_fullname()
|
|
|
|
if not(commodity_fullname) or (commodity_fullname == c_fullname):
|
|
print "["+str(i)+"] Full Name :", c.get_fullname()
|
|
if show_prices:
|
|
pl = pdb.get_prices(c,cur)
|
|
if pl:
|
|
print "{0} {1:20}{2:>10} {3}".format("Time ","Source","Price","Currency")
|
|
for i in pl:
|
|
pr = GncPrice(instance=i)
|
|
source = pr.get_source()
|
|
time = pr.get_time()
|
|
v=pr.get_value()
|
|
price = float(v.num)/v.denom
|
|
|
|
print "{0} {1:20}{2:10.4f} {3}".format(time,source,price,cur_name)
|
|
# I didn't find out how to format the time option...
|
|
|
|
session.end()
|
|
session.destroy()
|
|
quit()
|