By: Python Documentation Team
Python has a 'with' statement that wraps the execution of a block, calling code on the entrance and exit from the block. Some language have a construct that looks like this:
a = 1 # equivalent to obj.a = 1
total = total + 1 # obj.total = obj.total + 1
In Python, such a construct would be ambiguous.
Other languages, such as Object Pascal, Delphi, and C++, use static types, so itâ€™s possible to know, in an unambiguous way, what member is being assigned to. This is the main point of static typing â€“ the compiler always knows the scope of every variable at compile time.
Python uses dynamic types. It is impossible to know in advance which attribute will be referenced at runtime. Member attributes may be added or removed from objects on the fly. This makes it impossible to know, from a simple reading, what attribute is being referenced: a local one, a global one, or a member attribute?
For instance, take the following incomplete snippet:
The snippet assumes that â€œaâ€ must have a member attribute called â€œxâ€. However, there is nothing in Python that tells the interpreter this. What should happen if â€œaâ€ is, let us say, an integer? If there is a global variable named â€œxâ€, will it be used inside the with block? As you see, the dynamic nature of Python makes such choices much harder.
The primary benefit of â€œwithâ€ and similar language features (reduction of code volume) can, however, easily be achieved in Python by assignment. Instead of:
function(args).mydict[index][index].a = 21
function(args).mydict[index][index].b = 42
function(args).mydict[index][index].c = 63
ref = function(args).mydict[index][index]
ref.a = 21
ref.b = 42
ref.c = 63
This also has the side-effect of increasing execution speed because name bindings are resolved at run-time in Python, and the second version only needs to perform the resolution once.
Most Viewed Articles (in Python )
Latest Articles (in Python)
Comment on this tutorial
- Data Science
- Cloud Computing
- Java Beans
- Mac OS X
- Office 365
- Tech Reviews