Thanks Brad and Jim,

You're right, this isn't the latest Fedora release and I'm due for an
upgrade.

But...I saw this evening that a new version of the Gnucash 3.9 package was
available, with the changelog entry "Patch for Python accounting file bug."
I installed the update and my script works again. I did not need to add a
call to `gnucash_session.load()`, though I'll certainly consider trying
that if I encounter a similar problem in the future.

John

On Sat, Nov 30, 2024 at 4:24 PM Jim DeLaHunt <list+gnuc...@jdlh.com> wrote:

> John:
> On 2024-11-30 10:55, John Haiducek wrote:
>
> Hi,
>
> A Python script I've been using with Gnucash recently stopped working, and
> is no longer able to read files that could be read previously with the same
> script. The script can open Gnucash XML files, but it doesn't find the
> accounts in them. The script uses the official Gnucash Python API. Both
> Gnucash and the Python bindings were installed using the Fedora package
> manager.
>
> Here's the script:
>
> ```
> from sys import argv
> from gnucash import Session, SessionOpenMode
>
> def account_from_path(top_account, account_path, original_path=None):
>     if original_path==None: original_path = account_path
>     account, account_path = account_path[0], account_path[1:]
>
>     account = top_account.lookup_by_name(account)
>     if account == None:
>         raise Exception(
>             "path " + ':'.join(original_path) + " could not be found")
>
>     if len(account_path) > 0 :
>         return account_from_path(account, account_path, original_path)
>     else:
>         return account
>
> if __name__=='__main__':
>
>     gnucash_file = argv[1]
>
>     gnucash_session=Session(gnucash_file, SessionOpenMode.SESSION_READ_ONLY)
>
>     root_account = gnucash_session.book.get_root_account()
>
>     investments = account_from_path(root_account, ['Assets','Investments'])
> ```
>
> I'm experiencing this with Gnucash 5.9 on Fedora 39, installed using the
> Fedora repositories. I'm not sure how to tell whether this is a Gnucash
> bug, or a packaging error on the Fedora side, or something else. Any
> suggestions for diagnosing or troubleshooting this?
>
> You might need to add `gnucash_session.load()` after your call to
> Session().
>
> For background, see the thread "[GNC] unable to iterate accounts with API
> Python bindings" from October 2024 at
> <https://lists.gnucash.org/pipermail/gnucash-user/2024-October/113845.html>
> <https://lists.gnucash.org/pipermail/gnucash-user/2024-October/113845.html>.
> The crucial insight, from John Ralls:
>
> ...there's been only one change to the bindings since then: I removed a load 
> call from the Session constructor to fix bug 799308. That wasn't exactly the 
> right thing to do, but it's a surmountable problem: Load the session in the 
> script....
>
> I hope that is helpful. Best regards, —Jim DeLaHunt
>
>
_______________________________________________
gnucash-user mailing list
gnucash-user@gnucash.org
To update your subscription preferences or to unsubscribe:
https://lists.gnucash.org/mailman/listinfo/gnucash-user
-----
Please remember to CC this list on all your replies.
You can do this by using Reply-To-List or Reply-All.

Reply via email to