Obsidian media embedder
This is an extension for Python-Markdown which allows you to embed audio or video files as easily as images by simply writing:
data:image/s3,"s3://crabby-images/64804/648044f737bc31becac81db88809fcbc9db235a1" alt="my song"
data:image/s3,"s3://crabby-images/5861a/5861a01692509f098946ef7d40135634df72b2b7" alt="my video"
Additionally, this plugins allows to specify an image size the Obsidian way, e.g.:
data:image/s3,"s3://crabby-images/d8c9b/d8c9be8553f24976b7ec210a8d720f71a96d192c" alt="400x300" <!-- width and height -->
data:image/s3,"s3://crabby-images/d8c9b/d8c9be8553f24976b7ec210a8d720f71a96d192c" alt="400" <!-- only width -->
Supported formats are:
- Images:
avif
,bmp
,gif
,jpeg
,jpg
,png
,svg
,webp
. - Audio:
mp3
,wav
,m4a
,ogg
,3gp
,flac
. - Video:
mp4
,webm
,ogv
,mov
,mkv
. - Other:
not yet.md
,pdf
And even more than that! It embeds youtube videos too!
data:image/s3,"s3://crabby-images/9ca1b/9ca1bf1665add1b51891e59b1746d9ec67106e12" alt=""
Simply enable the extension like this:
import markdown
md = markdown.Markdown(extensions=['obsidian_media'])
print(md.convertFile('page.md'))
It can be used with MkDocs as following:
# mkdocs.yml
markdown_extensions:
- obsidian_media_mkdocs
For the best results, I recommend using it together with my mkdocs-obsidian-bridge. This would allow you to simply write:
![[assets/audio/my favourite song.mp3]]
![[assets/video/birthday party.mov]]
![[images/photo.jpg|400x300]]
![[images/photo.jpg|200]]
This extension is heavily inspired by orobardet/pymarkdown-video and motivated by @pipe-organ in GooRoo/mkdocs-obsidian-bridge#17.