39 Posts Tagged ‘mypy’ (Page 2)

(All tags.)


Python type hints: Mypy doesn’t allow variables to change type

Mypy does not allow variables to change type. I found this a little bit of a shock at first, but after I adapted, I found my code was more readable.

Read more...

Python type hints: upgrade syntax with pyupgrade

A couple of recent PEPs have made writing type hints easier:

Read more...

Python type hints: what’s the point of NoReturn?

Sometimes functions never return, for example by always raising an exception. For such functions’ return types, we can “get away” with using None, but it’s best to use the special NoReturn type). This allows Mypy to better find unreachable code (as covered previously). It also shows future readers that the lack of return is intentional.

Read more...

Python type hints: use Mypy’s unreachable code detection

I recently discovered Mypy has a secondary function as an unreachable code detector. This feature is a great way to highlight places bugs may be hiding, as code paths that can’t possibly run normally show a logical error.

Read more...

Python type hints: duck typing with Protocol

Duck typing says “if it quacks like a duck, treat it like a duck.” Type checking seems at odds with duck typing: we restrict variables to named types (classes), allowing only that type or subtypes. This seems like it would stop us from passing in arbitrary objects that can “quack the right way”. But since PEP 0544, we can declare “duckish” types with typing.Protocol.

Read more...

Python type hints: narrow types with isinstance(), assert, and Literal

Type narrowing is the ability for a type checker to infer that inside some branch, a variable has a more specific (narrower) type than its definition. This allows us to perform type-specific operations without any explicit casting.

Read more...

Python type hints: specify a class rather than an instance thereof

In a type hint, if we specify a type (class), then we mark the variable as containing an instance of that type. To specify that a variable instead contains a type, we need to use type[Cls] (or the old syntax typing.Type).

Read more...

Python type hints: enable postponed evaluation with __future__.annotations

Python 3.7 added a new “postponed evaluation” mode for type hints. In this post we’ll cover how it changes the behaviour of type hints, how to activate it, and the outstanding problems.

Read more...

Python type hints: debug types with reveal_type()

When working with type hints, it’s often useful to debug the types of variables. Type checkers allow you to do this with reveal_type() and reveal_locals().

Read more...

Python type hints: fix circular imports

Circular imports are always annoying when they arise in Python, and type hints make them more common. Thankfully, there’s a trick to add circular imports for type hints without causing ImportErrors.

Read more...

Python type hints: Create a TypedDict with non-identifier keys

Using TypedDict is a great way to type code that passes around dictionaries. The default way to create a TypedDict is with its class-based syntax:

Read more...

Python type hints: *args and **kwargs

When I started writing type hints, I was a little confused about what to do with Python’s variable argument operators, * and ** (often called *args and **kwargs). Here’s what I figured out.

Read more...

Python type hints: How to Use TypedDict

Take this function:

Read more...

Python type hints: Use object instead of Any

When starting out with Python type hints, it’s common to overuse typing.Any. This is dangerous, since Any entirely disables type checking for a variable, allowing any operation.

Read more...