Skip to main content

Helper Functions for hledger plain text accounting

Project description

hledger Helper (hhelper) - A Command-Line Tool for Managing hledger Files

Github

Welcome to hledger Helper (hhelper), a command-line tool for simplifying and enhancing your experience with hledger, the plain-text accounting tool. Whether you're managing transactions, cleaning up your journal, fetching commodity prices, or generating recurring transactions, hhelper is here to make your life easier.


🌟 Features

hledger Helper comes packed with powerful features to streamline your accounting workflow:

  1. Mark Transactions as Cleared Easily mark transactions as cleared directly from the command line. No more manual editing of your ledger files!

  2. Clean Up Journal Automatically clean and format your hledger journal file. This includes aligning amounts, removing unnecessary spaces, and ensuring your journal is valid.

  3. Fetch Prices Fetch historical commodity prices using Yahoo Finance and append them to your price file. Perfect for keeping your commodity valuations up to date.

  4. Generate Recurring Transactions Automatically generate recurring transactions based on your predefined rules. Save time by automating repetitive entries.


🚀 Getting Started

Prerequisites

  • Python 3.11 or higher
  • hledger 1.25 or higher
  • A valid config.toml file in ~/.config/hhelper/ (see example config)

Installation

# install uv (package manager):
curl -LsSf https://astral.sh/uv/install.sh | sh

# restart your terminal, or run the following command:
source $HOME/.local/bin/env # or follow instructions

# install hhelper through uv
uv tool install hhelper

# Run the tool
hh

🛠️ Usage

Once you've launched hhelper, you'll be greeted with a user-friendly menu where you can select from the available options:

  1. Mark Transactions as Cleared Navigate through your uncleared transactions and mark them as cleared with a single keypress.

  2. Clean Up Journal Automatically clean and format your journal file. The tool will ensure your journal is valid before making any changes.

  3. Fetch Prices Fetch historical prices for your commodities and append them to your price file. You can review the fetched prices before saving.

  4. Generate Recurring Transactions Generate recurring transactions based on a period expression. Preview the transactions before appending them to your journal.


⚙️ Configuration

hhelper requires a config.toml file located at ~/.config/hhelper/config.toml. This file should define the paths to your ledger, price, header, and recurring transaction files. Here's an example configuration:

[paths]
directory = "~/finance"
ledger_file = "journal.ledger"
price_file = "prices.ledger"
header_file = "header.ledger"
recurring_tx_file = "recurring.ledger"

[commodities]
commodity_pairs = [
    { symbol = "AAPL", base_currency = "USD", quote_currency = "AAPL", is_append_space = true },
    { symbol = "BTC-USD", base_currency = "USD", quote_currency = "BTC", is_append_space = false },
]

📜 License

This project is licensed under the MIT License. See the LICENSE file for details.


🙌 Contributing

Contributions are welcomed! If you have ideas for new features, improvements, or bug fixes, please open an issue or submit a pull request. Let's make hhelper even better together!


💬 Feedback

If you have any questions, suggestions, or just want to say hello, feel free to open an issue or reach out to us. We'd love to hear from you!


Happy accounting with hledger Helper! 🎉

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hhelper-0.1.1.tar.gz (30.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hhelper-0.1.1-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file hhelper-0.1.1.tar.gz.

File metadata

  • Download URL: hhelper-0.1.1.tar.gz
  • Upload date:
  • Size: 30.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.25

File hashes

Hashes for hhelper-0.1.1.tar.gz
Algorithm Hash digest
SHA256 fd3fc7009239993f560f353427ecf39ae74a4f0e6f6adf31b7e4076622e9acab
MD5 05ef3b41e0b0c09dd2484bea4183b414
BLAKE2b-256 0818ac9d18832d8943e727155ba1f08459e51ff0a4e6ae4b7f5cb4f680c7a649

See more details on using hashes here.

File details

Details for the file hhelper-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: hhelper-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 13.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.5.25

File hashes

Hashes for hhelper-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ce598a73d85aa50c47f7a154e75bf928e75478c7d9a00bad2a9fef44a9f7874a
MD5 bca1cd4f48a54bcd3ec69616c5057394
BLAKE2b-256 8a03c67502c98bc2ee278ef8bc44d921162507b4505924a31e5be475f2917dc9

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page