Python Class Variables

Summary: in this tutorial, you’ll learn how the Python class variables (or attributes) work.

Introduction to the Python class variables

Everything in Python is an object including a class. In other words, a class is an object in Python.

When you define a class using the class keyword, Python creates an object with the name the same as the class’s name. For example:

class HtmlDocument: passCode language: Python (python)

This example defines the HtmlDocument class and the HtmlDocument object. The HtmlDocument object has the __name__ property:

print(HtmlDocument.__name__) # HtmlDocumentCode language: Python (python)

And the HTMLDocument has the type of type:

print(type(HtmlDocument)) # <class 'type'>Code language: Python (python)

It’s also an instance of the type class:

print(isinstance(HtmlDocument, type)) # TrueCode language: Python (python)

Class variables are bound to the class. They’re shared by all instances of that class.

The following example adds the extension and version class variables to the HtmlDocument class:

class HtmlDocument: extension = 'html' version = '5'Code language: Python (python)

Both extension and version are the class variables of the HtmlDocument class. They’re bound to the HtmlDocument class.

Get the values of class variables

To get the values of class variables, you use the dot notation (.). For example:

print(HtmlDocument.extension) # html print(HtmlDocument.version) # 5Code language: Python (python)

If you access a class variable that doesn’t exist, you’ll get an AttributeError exception. For example:

HtmlDocument.media_typeCode language: Python (python)

Error:

AttributeError: type object 'HtmlDocument' has no attribute 'media_type'Code language: Python (python)

Another way to get the value of a class variable is to use the getattr() function. The getattr() function accepts an object and a variable name. It returns the value of the class variable. For example:

extension = getattr(HtmlDocument, 'extension') version = getattr(HtmlDocument, 'version') print(extension) # html print(version) # 5Code language: Python (python)

If the class variable doesn’t exist, you’ll also get an AttributeError exception. To avoid the exception, you can specify a default value if the class variable doesn’t exist like this:

media_type = getattr(HtmlDocument, 'media_type', 'text/html') print(media_type) # text/htmlCode language: Python (python)

Set values for class variables

To set a value for a class variable, you use the dot notation:

HtmlDocument.version = 10Code language: Python (python)

or you can use the setattr() built-in function:

setattr(HtmlDocument, 'version', 10)Code language: Python (python)

Since Python is a dynamic language, you can add a class variable to a class at runtime after you have created it. For example, the following adds the media_type class variable to the HtmlDocument class:

HtmlDocument.media_type = 'text/html' print(HtmlDocument.media_type)Code language: Python (python)

Similarly, you can use the setattr() function:

setattr(HtmlDocument, media_type, 'text/html') print(HtmlDocument.media_type)Code language: Python (python)

Delete class variables

To delete a class variable at runtime, you use the delattr() function:

delattr(HtmlDocument, 'version')Code language: Python (python)

Or you can use the del keyword:

del HtmlDocument.versionCode language: Python (python)

Class variable storage

Python stores class variables in the __dict__ attribute. The __dict__ is a mapping proxy, which is a dictionary. For example:

from pprint import pprint class HtmlDocument: extension = 'html' version = '5' HtmlDocument.media_type = 'text/html' pprint(HtmlDocument.__dict__)Code language: Python (python)

Output:

mappingproxy({'__dict__': <attribute '__dict__' of 'HtmlDocument' objects>, '__doc__': None, '__module__': '__main__', '__weakref__': <attribute '__weakref__' of 'HtmlDocument' objects>, 'extension': 'html', 'media_type': 'text/html', 'version': '5'})Code language: Python (python)

As clearly shown in the output, the __dict__ has three class variables: extensionmedia_type, and version besides other predefined class variables.

Python does not allow you to change the __dict__ directly. For example, the following will result in an error:

HtmlDocument.__dict__['released'] = 2008Code language: Python (python)

Output:

TypeError: 'mappingproxy' object does not support item assignmentCode language: Python (python)

However, you can use the setattr() function or dot notation to indirectly change the __dict__ attribute.

Also, the key of the __dict__ are strings that will help Python speeds up the variable lookup.

Although Python allows you to access class variables through the __dict__ dictionary, it’s not a good practice. Also, it won’t work in some situations. For example:

print(HtmlDocument.__dict__['type']) # BAD CODECode language: Python (python)

Callable class attributes

Class attributes can be any object such as a function.

When you add a function to a class, the function becomes a class attribute. Since a function is callable, the class attribute is called a callable class attribute. For example:

from pprint import pprint class HtmlDocument: extension = 'html' version = '5' def render(): print('Rendering the Html doc...') pprint(HtmlDocument.__dict__)Code language: Python (python)

Output:

mappingproxy({'__dict__': <attribute '__dict__' of 'HtmlDocument' objects>, '__doc__': None, '__module__': '__main__', '__weakref__': <attribute '__weakref__' of 'HtmlDocument' objects>, 'extension': 'html', 'render': <function HtmlDocument.render at 0x0000010710030310>, 'version': '5'}) Rendering the Html doc...Code language: Python (python)

In this example, the render is a class attribute of the HtmlDocument class. Its value is a function.


Comments

Leave a Reply

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