]> pere.pagekite.me Git - homepage.git/blob - blog/Ledger___double_entry_accounting_using_text_based_storage_format.html
0e8f35933dd4f90bf3b4840a9ae9e8a755313f57
[homepage.git] / blog / Ledger___double_entry_accounting_using_text_based_storage_format.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
2 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
3 <html xmlns="http://www.w3.org/1999/xhtml" dir="ltr">
4 <head>
5 <meta http-equiv="Content-Type" content="text/html;charset=utf-8" />
6 <title>Petter Reinholdtsen: Ledger - double-entry accounting using text based storage format</title>
7 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/style.css" />
8 <link rel="stylesheet" type="text/css" media="screen" href="http://people.skolelinux.org/pere/blog/vim.css" />
9
10
11 </head>
12 <body>
13 <div class="title">
14 <h1>
15 <a href="http://people.skolelinux.org/pere/blog/">Petter Reinholdtsen</a>
16
17 </h1>
18
19 </div>
20
21
22 <div class="entry">
23 <div class="title">Ledger - double-entry accounting using text based storage format</div>
24 <div class="date">18th December 2012</div>
25 <div class="body"><p>A few days ago I came across
26 <a href="http://joeyh.name/blog/entry/hledger/">a blog post from Joey
27 Hess</a> describing <a href="http://ledger-cli.org/">ledger</a> and
28 hledger, a text based system for double-entry accounting. I found it
29 interesting, as I am involved with several organizations where
30 accounting is an issue, and I have not really become too friendly with
31 the different web based systems we use. I find it hard to find what I
32 look for in the menus and even harder try to get sensible data out of
33 the systems. Ledger seem different. The accounting data is kept in
34 text files that can be stored in a version control system, and there
35
36 are at least <a href="https://github.com/ledger/ledger/wiki/Ports">five
37 different implementations</a> able to read the format. An example
38 entry look like this, and is simple enough that it will be trivial to
39 generate entries based on CVS files fetched from the bank:</p>
40
41 <blockquote><pre>
42 2004-05-27 Book Store
43 Expenses:Books $20.00
44 Liabilities:Visa
45 </pre></blockquote>
46
47 <p>The concept seemed interesting enough for me to check it out and
48 look for others using it. I found blog posts from
49 <a href="http://blog.spang.cc/posts/hledger_rocks_my_world/">Christine
50 Spang</a>,
51 <a href="http://bugsplat.info/2010-05-23-keeping-finances-with-ledger.html">Pete
52 Keen</a>,
53 <a href="http://blog.andrewcantino.com/blog/2010/11/06/command-line-accounting-with-ledger-and-reckon/">Andrew
54 Cantino</a> and
55 <a href="http://blog.iphoting.com/blog/2012/11/29/command-line-double-entry-accounting/">Ronald
56 Ip</a> describing how they use it, as well as a post from
57 <a href="https://groups.google.com/forum/?fromgroups=#!topic/ledger-cli/r0oWjwbQ9Bo">Bradley
58 M. Kuhn</a> at the Software Freedom Conservancy. All seemed like good
59 recommendations fitting my need.</p>
60
61 <p>The <a href="http://packages.qa.debian.org/l/ledger.html">ledger</a>
62 package is available in Debian Squeeze, while the
63 <a href="http://packages.qa.debian.org/h/haskell-hledger.html">hledger</a>
64 package only is available in Debian Sid. As I use Squeeze, ledger
65 seemed the best choice to get started.</p>
66
67 <p>To get some real data to test on, I wrote a
68 <a href="http://www.nuug.no/tools/lodo2ledger">web scraper</a> for
69 <a href="http://www.lodo.no/">LODO</a>, the accounting system used by
70 the <a href="http://www.nuug.no/">NUUG</a> association, and started to
71 play with the data set. I'm not really deeply into accounting, but I
72 am able to get a simple balance and accounting status for example
73 using the "<tt>ledger balance</tt>" command. But I will have to
74 gather more experience before I know if the ledger way is a good fit
75 for the organisations I am involved in.</p>
76 </div>
77
78 <div class="tags">Tags: <a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu</a>, <a href="http://people.skolelinux.org/pere/blog/tags/english">english</a>, <a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug</a>.</div>
79
80
81 </div>
82
83
84
85
86 <div id="sidebar">
87
88
89
90 <h2>Archive</h2>
91 <ul>
92
93 <li>2013
94 <ul>
95
96 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/01/">January (11)</a></li>
97
98 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/02/">February (9)</a></li>
99
100 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/03/">March (9)</a></li>
101
102 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/04/">April (6)</a></li>
103
104 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/05/">May (9)</a></li>
105
106 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/06/">June (10)</a></li>
107
108 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/07/">July (7)</a></li>
109
110 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/08/">August (3)</a></li>
111
112 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/09/">September (5)</a></li>
113
114 <li><a href="http://people.skolelinux.org/pere/blog/archive/2013/10/">October (2)</a></li>
115
116 </ul></li>
117
118 <li>2012
119 <ul>
120
121 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/01/">January (7)</a></li>
122
123 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/02/">February (10)</a></li>
124
125 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/03/">March (17)</a></li>
126
127 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/04/">April (12)</a></li>
128
129 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/05/">May (12)</a></li>
130
131 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/06/">June (20)</a></li>
132
133 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/07/">July (17)</a></li>
134
135 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/08/">August (6)</a></li>
136
137 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/09/">September (9)</a></li>
138
139 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/10/">October (17)</a></li>
140
141 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/11/">November (10)</a></li>
142
143 <li><a href="http://people.skolelinux.org/pere/blog/archive/2012/12/">December (7)</a></li>
144
145 </ul></li>
146
147 <li>2011
148 <ul>
149
150 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/01/">January (16)</a></li>
151
152 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/02/">February (6)</a></li>
153
154 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/03/">March (6)</a></li>
155
156 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/04/">April (7)</a></li>
157
158 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/05/">May (3)</a></li>
159
160 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/06/">June (2)</a></li>
161
162 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/07/">July (7)</a></li>
163
164 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/08/">August (6)</a></li>
165
166 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/09/">September (4)</a></li>
167
168 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/10/">October (2)</a></li>
169
170 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/11/">November (3)</a></li>
171
172 <li><a href="http://people.skolelinux.org/pere/blog/archive/2011/12/">December (1)</a></li>
173
174 </ul></li>
175
176 <li>2010
177 <ul>
178
179 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/01/">January (2)</a></li>
180
181 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/02/">February (1)</a></li>
182
183 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/03/">March (3)</a></li>
184
185 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/04/">April (3)</a></li>
186
187 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/05/">May (9)</a></li>
188
189 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/06/">June (14)</a></li>
190
191 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/07/">July (12)</a></li>
192
193 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/08/">August (13)</a></li>
194
195 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/09/">September (7)</a></li>
196
197 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/10/">October (9)</a></li>
198
199 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/11/">November (13)</a></li>
200
201 <li><a href="http://people.skolelinux.org/pere/blog/archive/2010/12/">December (12)</a></li>
202
203 </ul></li>
204
205 <li>2009
206 <ul>
207
208 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/01/">January (8)</a></li>
209
210 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/02/">February (8)</a></li>
211
212 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/03/">March (12)</a></li>
213
214 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/04/">April (10)</a></li>
215
216 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/05/">May (9)</a></li>
217
218 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/06/">June (3)</a></li>
219
220 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/07/">July (4)</a></li>
221
222 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/08/">August (3)</a></li>
223
224 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/09/">September (1)</a></li>
225
226 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/10/">October (2)</a></li>
227
228 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/11/">November (3)</a></li>
229
230 <li><a href="http://people.skolelinux.org/pere/blog/archive/2009/12/">December (3)</a></li>
231
232 </ul></li>
233
234 <li>2008
235 <ul>
236
237 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/11/">November (5)</a></li>
238
239 <li><a href="http://people.skolelinux.org/pere/blog/archive/2008/12/">December (7)</a></li>
240
241 </ul></li>
242
243 </ul>
244
245
246
247 <h2>Tags</h2>
248 <ul>
249
250 <li><a href="http://people.skolelinux.org/pere/blog/tags/3d-printer">3d-printer (13)</a></li>
251
252 <li><a href="http://people.skolelinux.org/pere/blog/tags/amiga">amiga (1)</a></li>
253
254 <li><a href="http://people.skolelinux.org/pere/blog/tags/aros">aros (1)</a></li>
255
256 <li><a href="http://people.skolelinux.org/pere/blog/tags/bankid">bankid (4)</a></li>
257
258 <li><a href="http://people.skolelinux.org/pere/blog/tags/bitcoin">bitcoin (7)</a></li>
259
260 <li><a href="http://people.skolelinux.org/pere/blog/tags/bootsystem">bootsystem (12)</a></li>
261
262 <li><a href="http://people.skolelinux.org/pere/blog/tags/bsa">bsa (2)</a></li>
263
264 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian">debian (86)</a></li>
265
266 <li><a href="http://people.skolelinux.org/pere/blog/tags/debian edu">debian edu (142)</a></li>
267
268 <li><a href="http://people.skolelinux.org/pere/blog/tags/digistan">digistan (10)</a></li>
269
270 <li><a href="http://people.skolelinux.org/pere/blog/tags/docbook">docbook (10)</a></li>
271
272 <li><a href="http://people.skolelinux.org/pere/blog/tags/drivstoffpriser">drivstoffpriser (4)</a></li>
273
274 <li><a href="http://people.skolelinux.org/pere/blog/tags/english">english (219)</a></li>
275
276 <li><a href="http://people.skolelinux.org/pere/blog/tags/fiksgatami">fiksgatami (21)</a></li>
277
278 <li><a href="http://people.skolelinux.org/pere/blog/tags/fildeling">fildeling (12)</a></li>
279
280 <li><a href="http://people.skolelinux.org/pere/blog/tags/freeculture">freeculture (12)</a></li>
281
282 <li><a href="http://people.skolelinux.org/pere/blog/tags/freedombox">freedombox (2)</a></li>
283
284 <li><a href="http://people.skolelinux.org/pere/blog/tags/frikanalen">frikanalen (11)</a></li>
285
286 <li><a href="http://people.skolelinux.org/pere/blog/tags/intervju">intervju (37)</a></li>
287
288 <li><a href="http://people.skolelinux.org/pere/blog/tags/isenkram">isenkram (7)</a></li>
289
290 <li><a href="http://people.skolelinux.org/pere/blog/tags/kart">kart (18)</a></li>
291
292 <li><a href="http://people.skolelinux.org/pere/blog/tags/ldap">ldap (8)</a></li>
293
294 <li><a href="http://people.skolelinux.org/pere/blog/tags/lenker">lenker (6)</a></li>
295
296 <li><a href="http://people.skolelinux.org/pere/blog/tags/ltsp">ltsp (1)</a></li>
297
298 <li><a href="http://people.skolelinux.org/pere/blog/tags/multimedia">multimedia (25)</a></li>
299
300 <li><a href="http://people.skolelinux.org/pere/blog/tags/norsk">norsk (235)</a></li>
301
302 <li><a href="http://people.skolelinux.org/pere/blog/tags/nuug">nuug (154)</a></li>
303
304 <li><a href="http://people.skolelinux.org/pere/blog/tags/offentlig innsyn">offentlig innsyn (8)</a></li>
305
306 <li><a href="http://people.skolelinux.org/pere/blog/tags/open311">open311 (2)</a></li>
307
308 <li><a href="http://people.skolelinux.org/pere/blog/tags/opphavsrett">opphavsrett (44)</a></li>
309
310 <li><a href="http://people.skolelinux.org/pere/blog/tags/personvern">personvern (66)</a></li>
311
312 <li><a href="http://people.skolelinux.org/pere/blog/tags/raid">raid (1)</a></li>
313
314 <li><a href="http://people.skolelinux.org/pere/blog/tags/reprap">reprap (11)</a></li>
315
316 <li><a href="http://people.skolelinux.org/pere/blog/tags/rfid">rfid (2)</a></li>
317
318 <li><a href="http://people.skolelinux.org/pere/blog/tags/robot">robot (7)</a></li>
319
320 <li><a href="http://people.skolelinux.org/pere/blog/tags/rss">rss (1)</a></li>
321
322 <li><a href="http://people.skolelinux.org/pere/blog/tags/ruter">ruter (4)</a></li>
323
324 <li><a href="http://people.skolelinux.org/pere/blog/tags/scraperwiki">scraperwiki (2)</a></li>
325
326 <li><a href="http://people.skolelinux.org/pere/blog/tags/sikkerhet">sikkerhet (31)</a></li>
327
328 <li><a href="http://people.skolelinux.org/pere/blog/tags/sitesummary">sitesummary (4)</a></li>
329
330 <li><a href="http://people.skolelinux.org/pere/blog/tags/skepsis">skepsis (4)</a></li>
331
332 <li><a href="http://people.skolelinux.org/pere/blog/tags/standard">standard (43)</a></li>
333
334 <li><a href="http://people.skolelinux.org/pere/blog/tags/stavekontroll">stavekontroll (3)</a></li>
335
336 <li><a href="http://people.skolelinux.org/pere/blog/tags/stortinget">stortinget (8)</a></li>
337
338 <li><a href="http://people.skolelinux.org/pere/blog/tags/surveillance">surveillance (18)</a></li>
339
340 <li><a href="http://people.skolelinux.org/pere/blog/tags/sysadmin">sysadmin (1)</a></li>
341
342 <li><a href="http://people.skolelinux.org/pere/blog/tags/valg">valg (8)</a></li>
343
344 <li><a href="http://people.skolelinux.org/pere/blog/tags/video">video (39)</a></li>
345
346 <li><a href="http://people.skolelinux.org/pere/blog/tags/vitenskap">vitenskap (4)</a></li>
347
348 <li><a href="http://people.skolelinux.org/pere/blog/tags/web">web (28)</a></li>
349
350 </ul>
351
352
353 </div>
354 <p style="text-align: right">
355 Created by <a href="http://steve.org.uk/Software/chronicle">Chronicle v4.6</a>
356 </p>
357
358 </body>
359 </html>