Creating Animated Data Stories | Data in Motion
Tl;DR
I was so wrong to neglect the power of Matplotlib for animations.
+++ interesting post on python visualizations
More jakevdp on Python and animations - Pro Stuff π
Intro
Not long ago, I was tinkering with AI/BI Tools.
Among them (ChartBrew, ChartDB, …) I was impressed by Streamlit x PyGWalker
 AI BI Tools Post
AI BI Tools PostFrom there, I could not resist to create this project: there will be some cool animations coming…
 Tinkering with Animations | Post
Tinkering with Animations | PostSometime ago, I was exploring some options to create video as a code
I tried something on RemotionJS on this repo
As always, there is a fireship cool video on Remotion:
But…it was not enough for me to get started with someting cool.
Maybe now this can be a thing, since we have MCP + Windsurf or GeminiCLI Configured with Git-MCP
{
  "mcpServers": {
    "gitmcp": {
      "serverUrl": "https://gitmcp.io/remotion-dev/remotion"
    },
    "context7": {
      "command": "npx",
      "args": ["-y", "@upstash/context7-mcp"]
    }
  }
}I created this repo for putting real life videos together, as covered on these posts
But it seems that today, we are going to have fun with [Matplotlib](#matplotlib-animations.
Animations with Python
Python is a versatile programming language that can be used for a wide range of tasks, including creating animations.
And on the mechanical engineering post, we saw how people are doing amazing Lorentz attractor animations.
Matplotlib Styled Charts
Before animating: be aware that you can create styled plots with matplotlib.
They wont be interactive, but they can look pretty cool!
Vibe Coding Proper Styled Matplotlib Charts π
If you are using Windsurf or similar tools, make sure to ask them to bring:
- Brand Colors
- Adding watermark / url or not
- Proper modules for: pull data, store data, transform data + style plots (you can have one for price, another for dividend oriented…)
- Output format size (resolution)
You can create a script with modes, in such a way that given few parameters, it will generate for you whatever domain specific chart you need.
But now…
Is it even possible to create a full .mp4 with code?
Matplotlib Animations
Apparently, it is: and not necesarily with plotly, as I tought
And again, people are doing fantastic stuff with matplotlib:
- https://jakevdp.github.io/blog/2012/08/18/matplotlib-animation-tutorial/
- https://jckantor.github.io/CBE30338/A.03-Animation-in-Jupyter-Notebooks.html
Even very interesting video use cases with them!
From Data to Streamlit to Animation to Video, is a topic that I tinkered during the AIssistant, here.
Now, the concept I want to do is very simple:
- Generate Code & Data driven animations
- Use Python to pull the data (and save the data for the records)
- Use matplotlib for the final .mp4animations
- Have as parameter the time of the animation and its output resolution
Something very similar, but with mechanisms, can be done as well!
But same as it can be done for mechanism, it can be done for time series data, like this SP500 returns which is powered by this script
Then, your imagination is the limit, as you can do scripts to compare few stocks returns and placing some OpenAI APi TTS audio that describes them:
- Create your AI-audio and matplotlib generated video (of 10s duration):
uv run ./OpenAI-Audio/openai-tts.py --env=./.env
ffmpeg -f s16le -ar 24000 -ac 1 -i audio_reply.pcm audio_reply.mp3 #transform it to mp3
uv run animate_sequential_compare_price_evolution_flex_custom.py MC.PA RMS.PA 2010-01-01 10 short
#ffprobe -v error -select_streams v:0 -show_entries stream=width,height -of csv=s=x:p=0 animated_yt_short.mp4Creating a “full circle” or cyclical narrative can be incredibly impactful for youtube shorts (1080x1920)
The trick is to reference the beginning in the end, but with the added context or impact of what was just revealed in the middle.
- Combine them and give 5 seconds time for the video to be paused and audio to keep going:
ffmpeg -y -i luxury-ytshort.mp4 -i audio_reply.mp3   -filter_complex "[0:v]tpad=stop_mode=clone:stop_duration=5[v_extended]"   -map "[v_extended]" -map 1:a:0   -c:v libx264 -preset fast -crf 23 -c:a aac   ./luxury-ytshort_extended_frozen_audio_added.mp4Conclusions
We’ve learnt how to do cool Python Animations.
Including cool .gif that you can easily share.
But, as you can imagine, there are more ways to generate animations as a code
- MotionCanvas
- Animotion
- RemotionJS
- The 3B1B way…
Ive been having the need to do some git recap:
You can organize your repository in a way that from one source code, you have different kind of outputs.
Say you have your animations for a website/twitter/whatever:
git branch libreportfolio 285484eafeae5c79436cef73678df8ae5153bc52
git checkout libreportfolioOr say you have similar data collection, but different outputs for some youtube channel:
git branch unfoldingdata 285484eafeae5c79436cef73678df8ae5153bc52
git checkout unfoldingdata
git branch -aEmbedded Analytics
Ipyvizzu
Probably oriented more if you are building PoCs at work.
Apache v2 | Build, present and share animated data stories in Jupyter Notebook and similar environments.
- https://ipyvizzu-story.vizzuhq.com/latest/
- https://ipyvizzu.vizzuhq.com/latest/installation/
- https://pypi.org/project/ipyvizzu-story/
FAQ
Social Media Automation
If you are able to create mp4 animations, you can also create images or animated .gif from them.
With those, you can go to different social media platforms and share the content you have just created.
Turning numbers into motivation!
— Libre Portfolio (@LibrePortfolio) July 3, 2025
See how every payment chips away at your debtβand how much goes to interest.
Stay consistent, and the finish line gets closer every month!#DebtPayoff #Amortization pic.twitter.com/RoiYgqAdBM
Social Media Management Apps: Social Media can be simplified with these apps:
Cool Data Driven Videos
Fractal stuff:
Data is beautiful, indeed:
How could I not mention the awsome 3B1B channel and its OSS animation engine, that I recommended here
Math Animation engine for explanatory math videos. The ones 3Blue1Brown Channel created!
Physical animations, like the Lorentz attactor:
if you love physics and mechanics as I do, this will captivate you.
https://youtu.be/xpvWHrgVZUg?si=a0wOyHHtd_KD2GtA
https://youtu.be/u2C3NMDrmCw?si=W2dMEVlUdvw2me8X
https://youtu.be/DZQ5-INW32Y?si=a1YPGn77-8vH-F8H
https://youtu.be/5xsUOmi-MxY?si=uK7sNHScVORAWf6R
https://youtu.be/5d_WxPEpr3Q?si=kMubQx542aCQlHlT
If you are into physics and mechanics…

