plaintextaccounting.org
Welcome! Plain text accounting is a way of doing bookkeeping and accounting with plain text files and scriptable, command-line-friendly software, such as Ledger, hledger, or Beancount. This site collects the PTA community's tools, docs and practices. It is maintained by Simon Michael (hledger project leader, PTA fan) and contributors like you. See also our discussion forum and chat rooms.
Site map
What is Plain Text Accounting ?
News & discussion
Videos
Slides
Docs: Accounting basics , app docs , comparisons , intros , cheatsheets , cookbooks , FAQs
FAQ
Cookbook
Software: Apps , Distros/setups , Features , Editor plugins , Data import/conversion , Price fetching , Data generation , Workflows , Formatting , Reporting , Time logging , UI, terminal , UI, GUI , UI, web , UI, mobile , Library , Utilities , API
This is a community-supported site; if you find it useful, why not contribute to the github repo or help with finance. Thank you sponsors, including:
Chat - matrix room - matrix space - IRC channel - project chats
Blogs & articles - See the PTA forum's News category and RSS feed - Older blogs & articles, 2006-2024
PTA forum - forum.plaintextaccounting.org
Reddit - /r/plaintextaccounting
Lemmy - lemmy.world/c/plaintextaccounting
Hacker News - stories - comments
Mastodon - #plaintextaccounting - #ledgercli - #hledger - #beancount
Twitter - #plaintextaccounting - #ledgercli - #hledger - #beancount - LedgerTips 2014-2018
Stack Exchange - ledger-cli tag - ledger-cli search - hledger tag - hledger search
Project specific - Project mail lists - This Week In Hledger
plaintextaccounting.org site - commits - contributors - issues - email the site admin
https://www.youtube.com/results?search_query=plaintextaccounting
- Thanga Ayyanar: Ledger CLI (in Tamil) 2024
- Edwin Espinoza: Ledger CLI, Personal finance in the command line 2023
- Prakash Joshi Pax: How to Use Obsidian to Track Your Expenses 2022
- Peter Berger: Plain Text Accounting: An Opinionated View 2022
- Glenn Ramsey: Plain text accounting for fun and profit 2022
- 季路LJ: Beancount |简略记账说明 2021
- Robert Nielsen: hledger fan channel short hledger beginner lessons, 2019-2021
- Brian Ryall: Managing Your Finances Using Python 2020
- Steve Anderson: Plain Text Accounting: How to do Signed Number Accounting 2019
- Quiliro Ordóñez: ledger-mode lightning talk 2019
- Dickson S. Guedes: Cuide de suas FINANÇAS pessoais ou profissionais usando TEXTO 2019
- John Nduli: Plain Text Accounting 2019
- Jean Louis: GNU Emacs database accounting and rant on text ledgers 2019
- Cindy Zimmerman: Triple Entry Accounting, Ledger-cli, The blocktree hash tree - Guld Ledger File Format 2018
- Colin Dean: Plaintext Accounting with the ledger ecosystem 2017
- Colin Dean: Plain Text Accounting 2017
- Simon Michael: Hands-on with hledger 2016
- Chris Vollick: hledger, an open source accounting tool 2016
- Austin Walker: Conquering Your Finances with Emacs and Ledger 2016
- Simon Michael, Randal Schwartz, Simon Phipps: FLOSS Weekly 375: hledger (3m overview, show notes) 2016
- John Wiegley, Randal Schwartz, Aaron Newcomb: FLOSS Weekly 150: Ledger (show notes) 2011
Accounting basics , PTA app docs , Comparisons , Intros , Cheatsheets , Cookbooks , FAQs
Apps , Distros/setups , Features , Editor plugins , Data import/conversion , Price fetching , Data generation , Workflows , Formatting , Reporting , Time logging , UI, terminal , UI, GUI , UI, web , UI, mobile , Library , Utilities , API
To do Plain Text Accounting, try one (or more) of the PTA apps below. Generally it's possible to migrate data between them.
Documented/reproducible setups, integrated docker images etc, based on the above.
Here's a comparison of the big three PTA apps' main features, plus some relevant third-party tools in italics, and some geeky technical specs that you may not care about. Corrections and suggestions are appreciated (chat).
| | | |
User interfaces | | | |
| CLI: | ledger | hledger | beanquery |
| TUI: | regdel | hledger add, hledger-ui, hledger-iadd, puffin | bean-add |
| GUI: | Prudent, ledgerble, addtrans | fruit-credits | |
| WUI: | ledgeraccounting, paisa, cashier, ledgible, ledger (howeyc), ledger-web (vifon), ledger-web (peterkeen), ledger-pyreport, ledger-analytics, node-ledger-web | hledger-web, ledgeraccounting, paisa, cashier | fava, paisa, BeanHub |
| Android: | cashier, NanoLedger | cashier, MoLe, NanoLedger | Beancount Mobile CE, beancount-mobile (xuhcc) |
| IOS: | | | Beancount Mobile CE |
| | | |
Getting-started | | | |
| Easy install and setup: | yes | yes | no |
| CLI help: | general --help, also available as man page | general and command-specific --help, commands summary, built-in asciinema demos | command-specific --help |
| TLDR short help: | ledger | hledger and commands, also built-in | |
| User manual formats: | web | web, info, man, also built-in info/man/text with jump to topic | web |
| Active support channels: | | chat, mail list, forum, reddit | mail list |
| | | |
Data formats | | | |
| Input formats: | journal (ledger), timeclock, csv | journal (hledger), timeclock, timedot, csv, tsv, ssv, *sv | journal (beancount) |
| Output formats: | text, csv, xml, lisp | text, html, csv, tsv, fods, beancount, sql, json | text, ? |
| | | |
Commands | | | |
| Commands: | accounts, balance, cleared, commodities, convert, csv, entry, emacs, equity, lisp, payees, pricemap, pricedb, prices, print, register, select, source, stats, tags | accounts, activity, add, aregister, balance, balancesheet, balancesheetequity, cashflow, check, close, codes, commodities, demo, descriptions, diff, files, help, import, incomestatement, payees, prices, print, notes, register, rewrite, roi, stats, tags, test | beancount: check, doctor, example, format |
| Add-on commands: | | bar, check-fancyassertions, edit, git, iadd, interest, lots, move, pijul, plot.. | beanquery: balances, journal, print, select |
| | | |
Configuration | | | |
| Config file: | general options | general and command-specific options | ? |
| Extensibility: | built-in expression language, embedded python, HTTP-JSON | add-on commands, haskell library, HTTP-JSON | data-modifying plugins, python library |
| | | |
Other features | | | |
| Account names: | any | any | capitalised, no spaces, english top level names |
| Account types awareness: | no | yes | yes |
| Budget report: | built-in | built-in | fava |
| Charting tools: | paisa, etc.. | activity, hledger-bar, hledger-web, hledger-plot, paisa, etc.. | fava, paisa.. |
| Commodity names: | any, on left or right, optional | any, on left or right, optional | 2-24 uppercase letters / digits / punctuation, on right, required |
| Data importing: | built-in from CSV, others.. | built-in from any input format, others.. | beangulp framework, beancount_reds_importers framework, beancount-import library, others.. |
| Data deduplication: | checksum-based (requires unique CSV records) | date-based (requires date-ordered CSV records) | ? |
| Date range: | 1400-01-01 to 9999-12-31 | 0000-01-01 onward | 0001-01-01 to 9999-12-31 |
| Generate postings by rule: | built-in | built-in | ? |
| Generate recurring transactions: | built-in | built-in | beancount-repete |
| International number notations: | no | yes | no |
| Lot management: | lot matching syntax, lots report, revaluation transactions, lotter | manual, hledger-lots, hledger-move, lotter | lot matching syntax, ? |
| Multi-period balance reports: | no | yes | fava |
| Pivoting: | on single tag | on one or more tags / other fields | no |
| Precision (journal): | 254 significant digits | "unlimited" integer digits + 255 decimal digits | 28 significant digits |
| Precision (internal): | "unlimited" (rational numbers) | "unlimited" integer digits + 255 decimal digits | 28 significant digits |
| Precision (balancing): | max precisions in local entry | global commodity precisions | max precisions in local entry / 2 (configurable) |
| Precision (display): | inferred commodity precision, or a default max precision of 6 | inferred / specified commodity precision, or a default max precision of 8 | inferred commodity precision, or a default max precision of 0 (configurable) |
| Price fetching: | pricehist | pricehist | beanprice, pricehist |
| Querying: | cli options, custom query expressions | cli options, custom query expressions, sql | SQL-like beancount query language |
| REPL: | built-in | haskell GHCI | beanquery, python |
| Shell completions: | bash (commands, flags, maybe accounts) | bash (commands, flags, flag values, query types, journal data) | |
| Unrealised gains report: | --unrealized | --gain, roi | fava |
| Validation: | configurable | configurable | always strict |
| Miscellaneous: | ? | standard financial reports | ? |
| | customisable account display order | |
| | customisable amount styles for input and output | |
| | documentation-first development | |
| | regular releases | |
| | regression bounties | |
| | | |
See also: hledger: Editor configuration
- Ledger and hledger have CSV conversion built in. Also:
- bean-identify, bean-extract, bean-file - import tools provided by Beancount v2
- banks2ledger - CSV to *ledger converter
- beanborg Advanced transaction importer with auto-categorization (python)
- beancount-import web app/framework for converting various formats to beancount (python)
- beancount-reds-importers Simple importers and tools for Beancount. A framework to allow you to easily write your own importers.
- beancount2ledger beancount to h/ledger converter (python)
- beanhub-extract Simple Python library for extracting all kinds of bank export CSV files into standardized transaction data objects
- beanhub-import Declarative idempotent rule-based beancount transaction import engine in Python consumes data extracted by beanhub-extract
- beanscrape CLI tool that automates using your browser to scrape bank data to beancount (C#)
- buchhaltung CSV/FinTS/HBCI/OFX to *ledger conversion/deduplication (haskell)
- Costflow convert one line message to beancount/*ledger format
- csv2beancount CSV to beancount converter (clojure)
- CSV2Ledger CSV to *ledger converter (perl)
- csv2ledger.el CSV to *ledger converter (emacs lisp)
- double-entry-generator Rule-based double-entry bookkeeping importer (from Alipay/WeChat/Huobi etc. to Beancount)
- finfetch local web app for downloading csv from your banks via Plaid (categorised, deduplicated, plus edits and deletions)
- fints2ledger FinTS/HBCI to csv to *ledger or beancount journals (python)
- grisbi2Ledger Grisbi to *ledger converter
- gsheet-csv.hs a script to download Google sheets (haskell)
- hledger-Excel Excel spreadsheet to *ledger journal converter (visual basic for applications)
- hledger-import-dsl alternate, programmable CSV converter for hledger
- hledger-to-influxdb hledger to InfluxDB converter (haskell)
- hledger2beancount hledger to beancount converter (haskell)
- homebank2ledger HomeBank to ledger and beancount converter (perl)
- icsvledger interactive CSV to *ledger converter (python)
- into-ledger CSV to *ledger converter
- invoice2data extract data from PDF invoices (python)
- jali downloader/importer to *ledger (python)
- ldgclip import bank transactions via the clipboard with one click (bash/awk)
- Ledger in Go has limport, a CSV to *ledger converter
- ledger-autosync OFX download, OFX to *ledger conversion, deduplication
- ledger-guesser neural network for generating entries like past ones, can be used with ledger-autosync (js)
- ledger-myexpenses MyExpenses android app sqlite db to *ledger conversion (python, 2017)
- ledgermyexpenses sync MyExpenses android app to/from Ledger (bash, 2023)
- ledger-to-beancount yet another simple ledger to beancount converter (python)
- ledger-tutorials convert Pete Keen's tutorials to ebook format
- ledger2beancount h/ledger to beancount converter (perl)
- ledger2beancount.py *ledger to beancount converter (python)
- limabean-harvest - Beancount importer with transaction pairing across accounts (clojure/rust)
- moneymoney-ledger MoneyMoney export extension for *ledger
- plaid2text Plaid API to *ledger/beancount download/conversion
- reckon smart interactive/non-interactive CSV to *ledger converter
- slc generates Ledger accounting entries, works with generic CSV files as well as the Stripe API
- smart_importer library for building smarter CSV to beancount/Fava converters
- Tiller service to download from mostly-US banks to google or microsoft spreadsheets (commercial but pretty good)
- total_recall CSV to *ledger converter
- outofit QuickBooks to *ledger converter
- plaid2qif Download transactions from plaid as QIF or CSV files
- qb2ledger QuickBooks General Journal CSV to *ledger converter
- QIFtoLedger (Bank of America's) QIF to *ledger converter
- beancount-ynab Import YNAB4 (legacy desktop-based version) into beancount
- beancount-ynab5 Import YNAB5 (cloud-based version) transactions into beancount
- ynab-to-ledger YNAB5 (transactions) to *ledger converter (2025)
- ynab-to-ledger You Need A Budget (YNAB) to *ledger converter. Handles multiple currencies, multiple number formats, reconciliation, memos, transfers, and split transactions
- ynab_to_ledger YNAB to *ledger converter
- beancount-extract-price generate prices transactions based on your beancount ledger (python)
- DepreciateForLedger generate *ledger depreciation transactions (python)
- hledger-interest generate *ledger interest entries (haskell)
- ledger-ts typescript EDSL for generating beancount journals (ts)
- ledgerbil schedule recurring txns, interactive reconcile, date sorting
- LedgerScheduler move entries from one file to another when they come due (python)
- lotter generate postings for capital gain/loss (go)
- recurring generate recurring *ledger entries (python)
- reorder-journal.sh sort hledger entries, preserving directives/comments at top of file (bash)
- sassetti adds lisp macros to ledger files (common lisp)
- kairos (repo) generate invoices from hledger timedot files (go)
- [docker-finance][dfi] hledger/hledger-flow/docker-based system for tracking, reporting, and metadata analysis of traditional and cryptocurrency finances
- Full-fledged hledger scripts and detailed tutorial for generating hledger journals from CSV files (haskell, shell)
- hledger-flow command-line tool to generate hledger (or Ledger) journals from CSV files (haskell)
- rtrledger another hledger journals from CSV files system, designed for chaotic German freelancers (shell etc.)
- Lazy Beancount Beancount packaged in Docker with additional plugins and tools
- budget_report budget reporting with beancount (python)
- gainstrack personal wealth analysis app with beancount export (scala+ts)
- hledger-diff report differing transactions between two journals (haskell)
- hledger-irr calculate an account's internal rate of return (superseded by roi) (haskell)
- hledger-lit show multiple charts in web browser (python)
- hledger-sankey Script + HTML files to plot income next to expense money flows from an hledger ledger file (shell + js)
- hledger-tools generating charts from hledger (ts)
- hledger-vega makes configurable vega-lite charts from hledger (shell)
- hreports customise hledger reports with templates and PDF output (python)
- ledger-plot interactive tool for making GNUplot charts from Ledger (python)
- ledger-plots R package & script to make charts from Ledger (R)
- r-ledger an R package for reading and reporting on ledger/hledger/beancount files (R)
- TaxingLots calculates capital gains for a ledger journal (python)
- bean-add interactive transaction entry tool (python, 2021..)
- dravik TUI for hledger viewing (python, 2025)
- hledger add interactive transaction entry tool (built-in command, 2009..)
- hledger-edit open any subset of transactions in your editor (python, 2023)
- hledger-iadd TUI for h/ledger transaction entry (haskell, 2015..)
- hledger-textual TUI for hledger viewing/entry/editing (python, 2026)
- hledger-ui TUI for h/ledger viewing (haskell, 2015.., video)
- ladd create and edit a new *ledger transaction by fuzzy-matching past descriptions (shell, 2020)
- ldgr command line tool to add/sort/tag ledger files (ruby, 2017)
- ledger xact history-aware transaction generator (built-in command, 2004..)
- ledger-add TUI for h/ledger transaction entry (python, 2024)
- puffin TUI for hledger viewing (go, 2023..)
- regdel TUI for viewing Ledger files (python, 2016)
- favagtk app of Fava web UI for beancount viewing (python+gtk, 2022..)
- fruit-credits data entry/reporting GUI for hledger (vala+gnome, 2024)
- ledgerble reporting GUI with charts & adjustable reports (js, 2019)
- ledgerhelpers misc. GUI tools + helper library (python+gtk, 2016..)
- Prudent integrated journal editing/importing/reporting GUI for Ledger (closed source, mac, js, 2019)
- Surebeans hledger-compatible YNAB clone, providing data entry, budgeting, reports (closed source, cross platform, C#, 2026)
- cash offline-capable web UI for data entry to CSV (js, 2024)
- fava web UI for beancount viewing (python, 2016.., demo)
- finfetch local web app for downloading csv from your banks via Plaid (ts, 2025)
- hledger-web web UI for *ledger viewing, data entry (haskell, 2010.., demo, Sandstorm app)
- hledger-webuix one-page local web app for hledger viewing, adding, editing (html+js, 2026)
- muhasib-e-hledger web UI for hledger reports (rust, 2024)
- Paisa web UI or desktop app for ledger, hledger and beancount (go/js/ts, 2022.., demo)
- Ledger in Go web UI for viewing ledger transactions, reports, and porfolios (go+js, 2021..)
- Ledger Web ledger HTML reporting system (ruby+postgres, 2011)
- Ledger Web web UI/API for ledger viewing, data entry (python, 2019)
- ledger-analytics web UI for ledger data analytics (js, 2018)
- ledger-dashboard web UI for ledger viewing, data entry (python, 2015)
- ledger-pyreport web UI for standard accounting statements and unrealised gains (python, 2020)
- ledgeraccounting web UI for hledger: data entry, basic reports and budgets (python+js, 2018)
- ledgible web UI for ledger viewing, data entry (python+js, 2016)
- nextcloud-hledger hledger UI on the Nextcloud file-sharing/web-app platform (php, 2021)
- node-ledger-web web UI for ledger viewing (js, 2014)
- WealthPulse web UI for ledger viewing, price fetching (F#+js, 2013)
- BeanHub web UI for beancount viewing, data entry with a Git repository (closed source with open source tools, python, 2022..)
- Beancount Mobile CE mobile app (Android/IOS, ts, 2020..)
- beancount-mobile data entry app (Android, ts, 2019)
- NanoLedger data entry app for h/ledger (Android, kotlin, 2023..)
- cashier mobile or desktop client for ledger and hledger-web (Android/Desktop, js, 2019, app)
- cone data entry app for the h/ledger format (Android, dart, 2019)
- MoLe mobile client for hledger-web (Android, java, 2020)
- hledger.org: Mobile apps
- gledger Go package to interface with Ledger (go)
- hledger-lib library for parsing and generating reports from *ledger files (haskell)
- hledger-web the web app includes a JSON API server for *ledger files (haskell)
- ledgerhelpers extends Ledger's python library (python)
- node-hledger Node.js API for *ledger files (js)
- pyhledger python scripts for parsing / converting to hledger format (python)
- BeanHub API SaaS API for operating on hosted beancount repositories and beanhub-forms
(c) 2016-2026 Simon Michael & contributors | Send updates via github, matrix, or IRC