Builder pattern

Hey there Pythonistas! Have you ever found yourself in a situation where you needed to create complex objects with lots of different properties? Or maybe you’ve been frustrated with having to remember a bunch of arguments to pass to a constructor every time you want to create an object. Fear not, because the builder pattern is here to save the day!

In this blog post, we’ll be diving into the builder pattern in Python and how it can make your life as a developer a whole lot easier. We’ll explore the basics of the pattern, how to implement it in Python, and some real-world use cases where the builder pattern really shines. So sit back, grab a cup of coffee (or tea, we don’t judge), and let’s get building!

Let’s start from the definition.

The builder pattern is a creational design pattern that helps simplify the creation of complex objects by separating the object creation process into multiple steps. It allows you to construct objects step by step, and lets you produce different types and representations of an object using the same construction code. By using the builder pattern, you can make your code more flexible, maintainable, and easier to read.

And now we can write some code. First, we create a Transaction class and a TransactionBuilder class. The TransactionBuilder class has methods to set each of the transaction’s properties. Once all the properties are set, the builder returns the fully constructed transaction object.


To create a transaction object using the builder pattern, we can do the following:


In this example, we’ve created a Transaction object step by step using the TransactionBuilder class. We’ve set the date, description, amount, and atomic_type using the builder’s methods, and then we’ve called the build() method to get the fully constructed transaction object.

Sounds easy, right? But what if we have more complex object, so more than one builder is needed.

In the example above we can see that Person class has 2 types of fields related to address and employment info. So as the first step we can create PersonBuilder which is simple builder with few additions.

Firstly, we will initialise the ‘person’ object by default with the Person() class. However, if the ‘person’ object already exists, we can utilize it instead. By doing so, we avoid creating a new instance of the ‘person’ object every time and instead reuse the existing one. This approach enables us to create a fluent interface and easily switch between builders.

Secondly, we will add two properties that will return two child builders: PersonJobBuilder and PersonAddressBuilder.

As the result we can use builder like this:


Let’s follow this logic step by step:

  1. We created instance of PersonBuilder with empty person, this means self.person = Person() code was executed in __init__ method
  2. We are getting property .lives that returns PersonAddressBuilder(self.person)
  3. Inside PersonAddressBuilder we are calling constructor of the parent class, this time person is not empty, so we use existing person instance
  4. This way we can fluently call .works property and continue to build our person object, without creation of new one

Leave a Reply

Your email address will not be published. Required fields are marked *