Loading video player…

Basic Data Classes

00:00 Basic data classes. Let’s get back to data classes. As an example, you’ll see a Position class that will represent geographic positions with a name as well as the latitude and longitude.

00:29 What makes this a data class is the @dataclass decorator just above the class definition. Beneath the class Position: line, you simply list the fields you want in your data class.

00:40 The colon (:) notation used for the fields is a feature that was introduced in Python 3.6 called variable annotations. You’ll soon see more about this notation and why we specify data types like str (string) and float. Those few lines of code are all you need.

00:56 The new class is ready for use.

01:25 You can also create data classes in a similar way to named tuples. The following is almost equivalent to the definition of Position you’ve just seen.

01:49 A data class is a regular Python class. The only thing that sets it apart is that it has basic data model methods such as .__init__(), .__repr__(), and .__eq__() implemented for you.

02:03 It’s easy to add default values to the fields of your data class.

02:24 This works exactly as if you had specified the default values in the definition of the .__init__() method of a regular class.

02:46 Later in the course, you’ll learn about default_factory, which gives a way to provide more complicated default values. So far, we have not made a big fuss of the fact that data classes support typing out of the box.

03:00 You’ve probably noticed that we defined a field with a type hint: name: str says that name should be a text string. In fact, adding some kind of type hint is mandatory when defining the fields in your data class. Without a type hint, the field will not be a part of the data class.

03:20 However, if you don’t want to add explicit types to your data class, use Any from the typing module.

03:46 While you need to add type hints in some form when using data classes, these types are not enforced at runtime. The following code runs without any problems.

04:01 This is how typing in Python usually works: Python is and will always be a dynamically typed language. To actually catch type errors, type checkers like Mypy can be run on your source code.

04:16 You already know that a data class is just a regular class. This means you can freely add any methods you want to that class. As an example, let us calculate the distance between one position and another along the Earth’s surface. One way to do this is by using the haversine formula, which is seen onscreen.

04:39 You can add a .distance_to() method to your data class just like you can with normal classes. And here, you’ll see the distance method being added to the Position data class.

06:18 Now that you’ve seen the basics of data classes, in the next section, you’ll see how to make them more flexible.

Avatar image for marianogg9

marianogg9 on Dec. 31, 2024

hey @darren - when explaining Any types in a dataclass with the WithoutExplicitType class, why did you create a Position class object instead? min 04:00

Avatar image for Darren Jones

Darren Jones RP Team on Dec. 31, 2024

Sorry, that is a little unclear - it’s actually referring back to the fact that you can supply different types to the Position class and that they are not enforced at runtime; the WithoutExplicitType class is showing that you can use typing.Any to create a dataclass without types being annotated within.

Become a Member to join the conversation.