Aufgaben hinzufügen#
RMarkdown-Datei mit Lösungen herunterladen
RMarkdown-Datei ohne Lösungen herunterladen
Aufgaben der RTraining-Plattform sind in RMarkdown geschrieben und werden automatisch vom Skript rmd2myst.R in myst-Markdown übersetzt. myst-Markdown ist die von JupyterBook unterstützte Markdown Version. Neue Aufgaben werden hinzugefügt, indem diese als Rmd-Dateien im Ordern Aufgaben_rmd gespeichert werden. Zusätzlich muss der Name der Datei (z.B. bei “neue_Aufgabe.Rmd” ist der Name “neue_Aufgabe”) im Dokument _toc.yml hinzugefügt werden. Der Name der Datei darf keine Umlaute enthalten und statt Leerzeichen muss man Unterstriche nutzen, z.B. statt “Einführung in R”, muss die Datei “Einfuehrung_in_R” bennant werden.
Wenn die Aufgabe R-Pakete nutzt, muss zusätzlich überprüft werden, ob dieses bereits installiert wird. Alle bisher installierten Pakete werden im Dokument environment.yml aufgefüht. Hier steht beispielsweise:
dependencies:
- ...
- r-tidyverse
Es wird also das gesamte tidyverse installiert. Wenn wir das Paket psych
hinzufügen
wollen, dann müssen wir erst schauen, ob es dieses für Anaconda gibt. Hierfür
gehen wir auf anaconda.org und suchen nach r-psych
.
Wichtig: R-Pakte fangen auf Anaconda immer mit r-
an! r-psych
existiert auf Anaconda und wir können es daher einfach hinzufügen, indem
wir es in environment.yml
ergänzen:
dependencies:
- ...
- r-tidyverse
- r-psych
Das Paket wird nun bei nächsten Erstellen der Webseite installiert und kann mit
library(psych)
aufgerufen werden.
Die automatische Übersetzung unterstützt zur Zeit leider nicht alle Funktionen
von RMarkdown. Das betrifft insbesondere die tags, die in R Code-Blöcken genutzt
werden können (z.B. eval = FALSE
). Außerdem können nicht alle html-tags (z.B.
aside
oder details
) vollumfänglich genutzt werden.
Im Folgenden werden die unterstützten Optionen demonstriert. Der Quelltext ist in GitHub hinterlegt.
Code-Blöcke#
Die folgenden Code-Blöcke werden unterstützt:
Code-Block mit eval = FALSE#
In Rmarkdown-Style:
# nicht ausgeführter Code
print(3)
In quarto-Style:
# nicht ausgeführter Code
print(3)
Code-Block mit echo = FALSE#
In Rmarkdown-Style:
[1] 3
In quarto-Style:
[1] 3
Code-Block mit include = FALSE#
In Rmarkdown-Style:
In quarto-Style:
Details#
Details nur mit Text:
Details nur mit code:
Show code cell content
# details mit code-Block
print(2)
[1] 2
Wichtig: Text und Code darf in details
nicht kombiniert werden!
Details - code-Block mit eval = FALSE#
In Rmarkdown-Style:
# nicht ausgeführter Code
print(3)
In quarto-Style:
print(3)
Details - code-Block mit echo = FALSE#
In Rmarkdown-Style:
Show code cell content
# nicht ausgeführter Code
print(3)
[1] 3
In quarto-Style:
Show code cell content
# nicht ausgeführter Code
print(3)
[1] 3
Aufgaben - Inhalt#
Die Aufgaben beziehen sich auf die Inhalte der R-Lernplattform und werden entsprechend unterteilt und benannt, z.B. “Einführung in R”. Es gibt keine explizite Anzahl an Aufgaben, die für jeden Abschnitt erstellt werden, sondern es wird sich an den Inhalt orientiert. Pro Themenbereich werden 1-2 Aufgaben erstellt mit dem Ziel, das Wissen, das in dem Abschnitt vermittelt wird, weitestgehend abzufragen. Die Aufgaben können auch mehrere Themenbereiche gleichzeitig abfragen und können (bzw. sollen) in Ihrer Schwierigkeit variieren.
Jede Aufgabe besteht aus drei Teilen: 1) Themenbereich, 2) Aufgabe in schriftlicher Form und 3) Lösung als code-Block.
Der Themenbereich dient als die Unterschrift, z.B. “Objekt, Logische Operationen” und wird mit 2 oder mehr “#” prefixiert. Nur die Überschrift bzw. der Name des Aufgabenabschnitts (z.B. “Einführung in R”) wird mit einem einzelnen “#” prefixiert.
Die Aufgaben werden per “du” geschrieben. Die Aufgaben werden nicht nummeriert.
Der Anfang und das Ende der Lösung wird mit
<!-- loesung: start-->
bzw.<!-- loesung: ende-->
markiert. Z.B.:
<!-- loesung: start-->
Show code cell content
x <- 5000
y <- 8^4
y <= x
<!-- loesung: ende-->
Die Tags <!-- loesung: start-->
bzw. <!-- loesung: ende-->
müssen immer in einer eigenen Zeile stehen. Folgendes
ist nicht erlaubt:
“Berechne 123*456 in R. <!-- loesung: start-->
123*456
<!-- loesung: ende-->
”.
Korrekt wäre:
“Berechne 123*456 in R.
<!-- loesung: start-->
123*456
<!-- loesung: ende-->
”.
Checkliste#
Diese Checkliste kann zur Selbstüberprüfung verwendet werden:
R Übungsaufgaben erstellen
Lösungen mit “
<!-- loesung: start-->
Meine Lösung steht hier<!-- loesung: ende-->
” markierenHeader level überprüfen: Nur die erste Überschrift darf auf Level 1 sein (# Erste Überschrift) alle anderen Unterschriften müssen auf höherem Level sein (## Unterschrift)
Dokumenten-Name überprüfen: Nur “Standard”-Buchstaben verwenden (kein ßäöü) und Unterstriche statt Leerzeichen verwenden
Dokument auf GitHub hochladen
Dokument zu _toc.yml hinzufügen
Überprüfen, ob alle benötigten Pakete bereits im [environment.yml] installiert sind. Wenn nicht dann hinzufügen.
Pull request erstellen