Creating dynamic headers in Reportlab

When writing code to make a report, you never truly know what you are going to get into. In a recent Python project, I was using the excellent ReportLab libraryand things were going smoothly. But then I needed make a header that would appear on every page. This isn’t took bad – you just create a function that goes on the document when you build it. But the API doesn’t support that terribly well – the function that you give to the Document object takes the Document and the Canvas as the only parameters… but I have content to put in there!

In the dusty part of my brain I remembered currying functions from reading several years ago. They are also called “partial functions”. As a surprise to no one, Python 3 has a standard library function for this. As I combined that with how I knew the header had to be made, I was impressed how simple it seemed to be. The code isn’t complicated at all!

Here is a Gist with how I set this up. Some understanding of ReportLab is assumed, but I think it works well. You can do something similar for a footer as well. Actually you can have both render in the same function.

About the Author

Object Partners profile.
Leave a Reply

Your email address will not be published.

Related Blog Posts
Natively Compiled Java on Google App Engine
Google App Engine is a platform-as-a-service product that is marketed as a way to get your applications into the cloud without necessarily knowing all of the infrastructure bits and pieces to do so. Google App […]
Building Better Data Visualization Experiences: Part 2 of 2
If you don't have a Ph.D. in data science, the raw data might be difficult to comprehend. This is where data visualization comes in.
Unleashing Feature Flags onto Kafka Consumers
Feature flags are a tool to strategically enable or disable functionality at runtime. They are often used to drive different user experiences but can also be useful in real-time data systems. In this post, we’ll […]
A security model for developers
Software security is more important than ever, but developing secure applications is more confusing than ever. TLS, mTLS, RBAC, SAML, OAUTH, OWASP, GDPR, SASL, RSA, JWT, cookie, attack vector, DDoS, firewall, VPN, security groups, exploit, […]