Announcing the chefkoch tool

I am happy to announce that yesterday I released version 1.0 of chefkoch. Chefkoch is a simple command line script written in Haskell. Its purpose is to download recipe information from the cooking website www.chefkoch.de, thus the name for the script. You can find the source code on github.

Motivation

I am not a very skilled cook. I am neither very creative with the choice of my dishes and ingredients, neither am I very good in remembering recipes.

Thus for people like me cooking websites are a very nice option to bring some variety to the kitchen without investing to much time. My website of choice is the above mentioned website (in German, sorry…).

But I, personally, don’t like two things:

  1. The website is way to overloaded with flashy, colorful media, distracting from the really important information
  2. It is hard to find nice recipes because you don’t know the keywords to look for

I am not critizing the first point so much, because it is important to make a website look nice and of course they want to make a bit money off of it, so there is advertisement. But as a programmer I know I have a way to get around all this clutter…

The second point is actually more a problem of me than of the website. If you don’t know what to look for, it is hard to find it :P

The website offers tags and a search option of course, but just looking for ‘potatoes’ is a bit of a too broad search. But the website is offering another nice feature that I like: recipe of the day. For every calendar day they choose one dish and present it. I am actually using this possibility to find a wide variety of meals in a realitvely easy way.

So these were the two intentions I had when I started writing this script:

  1. Only extract the importatnt information of the recipe (ingredients and instructions) along with a bit meta data
  2. Provide a programmatic way to access the recipe of the day recipes

Usage

The fact that its possible to output the recipes in JSON or YAML syntax opens a wide range of post processing and pipeline options. From the start of the project it was a goal of mine to support these output formats. In addition the YAML output pretty prints nicely to for reading.

There exist 3 options to access a recipe:

  1. By providing a link
  2. By providing the year, month and day
  3. Choosing at random
$ chefkoch --link https://www.chefkoch.de/rezepte/1316541236346986/Kaesekuchen-von-Tante-Gertrud.html --output -
- Url: https://www.chefkoch.de/rezepte/1316541236346986/Kaesekuchen-von-Tante-Gertrud.html
  Instructions: ! 'Für eine 28er Springform.Aus den Teigzutaten einen Knetteig herstellen
    und diesen gleichmäßig in einer Springform verteilen und bis an den Rand hochziehen.Die
    Zutaten für die Füllung miteinander mischen und die Quarkmasse (Achtung, sie ist
    dünnflüssig!) in die mit dem Teig ausgekleidete Form füllen. Im vorgeheizten Backofen
    bei 200 Grad (Umluft 175 Grad) gut eine Stunde backen.Achtung: Den Kuchen erst
    nach dem völligen Erkalten aus der Form nehmen, da unmittelbar nach dem Herausnehmen
    aus dem Backofen die Konsistenz der Quarkmasse noch zu weich ist.Belohnt werdet
    Ihr mit einem Käsekuchen, wie Ihr ihn sicherlich noch nie gegessen habt und wie
    Ihr ihn auch mit diesem Geschmack bei keinem Bäcker zu kaufen bekommt.Ich habe
    dieses Rezept schon x-mal gemacht. Der Kuchen ist einfach super! Das Beste an
    ihm ist, dass er wirklich nicht zusammenfällt, obwohl die Quarkmasse am Anfang
    flüssig ist. Er bleibt auch nach dem Backen so hoch, wie er in der Kuchenform
    ist.Das ist für mich das beste Käsekuchenrezept, das es gibt.'
  Ingredients:
  - ! 'Für den Teig:'
  - 330 g Mehl
  - 130 g Zucker
  - 130 g Butter, oder Margarine
  - 2 m.-große Ei(er)
  - 2 Pck. Vanillezucker
  - 1 Pck. Backpulver
  - ! 'Für die Füllung:'
  - 1 kg Magerquark
  - 300 g Zucker
  - 2 Pck. Puddingpulver, Vanille zum Kochen
  - 100 ml Öl (Sonnenblumenöl)
  - 600 ml Milch
  - 4 Ei(er)
  - evtl. Zitronenschale, abgeriebene, oder Rum-Aroma (für Quarkmasse)
  Day: null
  Name: ''
  Year: null
  Month: null
  Weekday: null

By Date

Random