Inline Python Editors
Bottom.ch with direct component
This is the preferred version as of 2025.
<!-- Include the script once (or from a DokuWiki plugin, or from userscripts. --> <html><script type="module" src="https://bottom.ch/ksr/ed/bottom-editor.js"></script></html> <!-- Include a custom component in HTML. Use height, min-height, max-height to control the size. --> <!-- Leading empty lines will be dropped. --> <html><bottom-editor style="min-height: 10lh;" autorun> print(42) </bottom-editor></html>
You can install files from an URL (with CORS headers if from a different domain!):
<html><bottom-editor zip='https://bottom.ch/ksr/py/files/2m.zip'> with open('gemeinden.csv', 'r') as infile: for line in infile: tokens = line.split(',') town = tokens[0] if town == 'Romanshorn': print(f'Romanshorn hat {tokens[2]} Einwohner') </bottom-editor></html>
WebtigerPython iframe
<html><iframe src="https://webtigerpython.ethz.ch/?layout=%5B%7B%22type%22%3A%20%22Editor%22%7D%2C%7B%22type%22%3A%20%5B%22Canvas%22%2C%22Console%22%5D%7D%5D&lang=de&full_screen=false&dark_mode=false&device=-&code=NobwRAdghgtgpmAXGGUCWEB0AHAnmAGjABMoAXKJMAMwCcB7GAAjIFdayAbOJtGbehyYAqADoRxdNGQBeTALxMAKuy5wAFAEpJtaTMzVBAdyi1i6gKwAGbRCmzM3amXUBOGzr0Hjp89dv2%2Bk4u7gG6Doa0JmaWHnbhQXDObnGB3lG%2BsWFewSm2YAC%2BALpAA%3D" allow="usb;clipboard-write" style="border: 1px solid lightgray; height: 500px; width: 100%"> </iframe> </html>
Bottom.ch with iframe
With iframe on bottom.ch/ksr/py/embed.html, which is based on pyodide and codemirror.
<html><iframe frameborder="0" width="100%" allow="clipboard-write" src="https://tkilla77.github.io/python_editor_wasm/embed_old.html?autorun&code=print%28%27Hello%2C+dokuwiki%21%27%29"></iframe></html>