emacs-orgmode@gnu.org archives
 help / color / mirror / code / Atom feed
From: Stefan Huchler <stefan.huchler@mail.de>
To: emacs-orgmode@gnu.org
Subject: Re: Multi-step ledger org-capture template
Date: Sun, 26 Aug 2018 23:53:43 +0200	[thread overview]
Message-ID: <87wosciyl4.fsf@mail.de> (raw)
In-Reply-To: 87o9dtjov4.fsf@mail.de

In case somebody wants something similar, I post my solution I came up
with here:

%(progn
   (defun get-table-content (&optional start end)
     (let* ((start (or start (buffer-end -1)))
	    (end (or end (buffer-end 1)))
	    (lines
	     (s-split "\n" (buffer-substring-no-properties
			    start end))))
       (remove nil
	       (mapcar
		(lambda (line)
		  (mapcar
		   (lambda (elem)
		     (string-trim elem))
		   (remove "" (split-string
			       line "|"))))
		lines))))
   (with-current-buffer (org-capture-get :original-buffer)
     (call-interactively 'copy-region-as-kill))
   (let* (mapping)
     (with-temp-buffer
       "*shop-name-mapping*"
       (erase-buffer)
       (insert-file-contents "capture-templates/products-mapping.org")
       (let* ((start (progn (goto-char (point-min))
			    (forward-line 1) (point))))
	 (setq mapping (mapcar (lambda (x) (cons (nth 1 x) (car x)))		       
		       (get-table-content start)))))
     (with-temp-buffer
       "*shop-import-temp*"
       (erase-buffer)
       (yank)
       (org-table-convert-region (buffer-end -1) (buffer-end 1) 2)    
       (let* ((data (get-table-content)))
	 (erase-buffer)
	 (insert
	  (concat "  " (org-read-date nil nil) " * Shop-name\n"
		  (mapconcat
		   (lambda (line) (format "      %s \t\t%s St {=€%s}"
			     (assoc-default (nth 1 line) mapping)
			     (nth 0 line) (nth 4 line)))
		   data "\n")
		  "\n      assets:bank:chequing"))
	 (ledger-mode)
	 (let ((start (progn
			(goto-char (point-min))
			(forward-line 1) (point)))
	       (end (progn
		      (goto-char (point-max))
		      (forward-line -1) (point))))
	   (ledger-post-align-postings start end))	 
	 (buffer-string)))))

products-mapping would like like that:

#+NAME: food
| expenses:food:spice:Basilikum | Basilikum bio Sonnentor, 15g |
| expenses:food:spice:Oregano   | Oregano bio Sonnentor, 20g   |

Of course it asumes that you have some html or email bill with a table
selected and you would have to change the (nth x line) depending where
in the bill the name, amount and price is listed, and maybe change the
currency.

  reply	other threads:[~2018-08-26 21:53 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-08-21 11:45 Multi-step ledger org-capture template Stefan Huchler
2018-08-22 22:48 ` Stefan Huchler
2018-08-23 11:37   ` Stefan Huchler
2018-08-26 21:53     ` Stefan Huchler [this message]
2018-08-27  8:05       ` ST
2018-08-28  8:24         ` Neil Jerram

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.orgmode.org/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=87wosciyl4.fsf@mail.de \
    --to=stefan.huchler@mail.de \
    --cc=emacs-orgmode@gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs/org-mode.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).