Top Related Projects
Static Type Checker for Python
It's not just a linter that annoys you!
Performant type-checking for python.
A static type analyzer for Python code
flake8 is a python tool that glues together pycodestyle, pyflakes, mccabe, and third-party plugins to check the style and quality of some python code.
An extremely fast Python linter and code formatter, written in Rust.
Quick Overview
Mypy is an optional static type checker for Python. It combines the benefits of dynamic typing and static typing by adding type hints to Python code, allowing developers to catch errors early in the development process. Mypy aims to make Python more scalable, maintainable, and reliable, especially for large codebases.
Pros
- Catches type-related errors before runtime, improving code quality and reducing bugs
- Enhances code readability and self-documentation through type annotations
- Provides better IDE support for autocompletion and refactoring
- Gradual typing allows for incremental adoption in existing projects
Cons
- Adds extra development overhead, especially when first introducing type annotations
- May have false positives or miss some type-related issues in complex scenarios
- Requires additional setup and integration into the development workflow
- Some Python libraries may lack type stubs, limiting the effectiveness of type checking
Code Examples
- Basic type annotations:
def greet(name: str) -> str:
return f"Hello, {name}!"
result: str = greet("Alice")
print(result)
- Using generic types:
from typing import List, Dict
def process_data(items: List[int]) -> Dict[str, int]:
return {
"sum": sum(items),
"length": len(items)
}
data: List[int] = [1, 2, 3, 4, 5]
result: Dict[str, int] = process_data(data)
print(result)
- Type checking with custom classes:
class Person:
def __init__(self, name: str, age: int) -> None:
self.name = name
self.age = age
def is_adult(person: Person) -> bool:
return person.age >= 18
alice: Person = Person("Alice", 25)
print(is_adult(alice))
Getting Started
To start using Mypy:
-
Install Mypy:
pip install mypy
-
Add type annotations to your Python code.
-
Run Mypy on your project:
mypy your_file.py
-
Address any type errors reported by Mypy.
-
Optionally, integrate Mypy into your development workflow (e.g., pre-commit hooks, CI/CD pipeline).
Competitor Comparisons
Static Type Checker for Python
Pros of Pyright
- Faster performance, especially for large codebases
- Built-in Language Server Protocol (LSP) support
- More comprehensive type inference in some cases
Cons of Pyright
- Less mature and established compared to Mypy
- Smaller community and ecosystem
- Some advanced features require configuration
Code Comparison
Mypy:
from typing import List
def greet(names: List[str]) -> None:
for name in names:
print(f"Hello, {name}!")
Pyright:
def greet(names: list[str]) -> None:
for name in names:
print(f"Hello, {name}!")
The main difference in this example is the use of List
from the typing
module in Mypy, while Pyright supports using the built-in list
type directly for type annotations.
Both tools provide similar functionality for type checking Python code, but they have different strengths and trade-offs. Mypy has been around longer and has broader adoption, while Pyright offers performance benefits and tighter integration with some development environments. The choice between them often depends on specific project requirements and personal preferences.
It's not just a linter that annoys you!
Pros of Pylint
- More comprehensive linting capabilities, covering style, error detection, and coding standards
- Highly configurable with numerous options to customize checks and reporting
- Integrates well with various IDEs and text editors
Cons of Pylint
- Can be slower than Mypy, especially on larger codebases
- May produce more false positives, requiring fine-tuning of configuration
- Learning curve can be steeper due to extensive configuration options
Code Comparison
Pylint example:
import math
def calculate_area(radius):
return math.pi * radius ** 2
Mypy example:
import math
def calculate_area(radius: float) -> float:
return math.pi * radius ** 2
The main difference in these examples is that Mypy focuses on type annotations, while Pylint would check for various style and potential error issues beyond just types.
Pylint is a more comprehensive linting tool that covers a wide range of code quality checks, including style, potential errors, and coding standards. It offers extensive configuration options but may require more setup time.
Mypy, on the other hand, is primarily a static type checker for Python, focusing on type annotations and type-related issues. It's generally faster and more straightforward to use for type checking but doesn't cover the broader range of linting checks that Pylint does.
Performant type-checking for python.
Pros of Pyre-check
- Faster performance, especially for large codebases
- Better support for incremental type checking
- More advanced features like taint analysis and security checks
Cons of Pyre-check
- Smaller community and ecosystem compared to Mypy
- Less comprehensive documentation and learning resources
- May have compatibility issues with some third-party libraries
Code Comparison
Mypy:
from typing import List
def greet(names: List[str]) -> None:
for name in names:
print(f"Hello, {name}!")
Pyre-check:
from typing import List
def greet(names: List[str]) -> None:
for name in names:
print(f"Hello, {name}!")
The code for basic type checking is identical for both tools. However, Pyre-check offers additional features for more complex scenarios, such as taint analysis:
from pyre_extensions import taint_model
@taint_model
def process_user_input(input: str) -> str:
return input.strip()
This example demonstrates Pyre-check's taint analysis capabilities, which are not available in Mypy. Overall, while both tools serve similar purposes, Pyre-check offers some advanced features and performance benefits, particularly for larger projects, at the cost of a smaller ecosystem and potentially more challenging setup process.
A static type analyzer for Python code
Pros of pytype
- Performs more advanced type inference, including for unannotated code
- Supports gradual typing, allowing for incremental adoption
- Offers better handling of dynamic Python features like metaclasses
Cons of pytype
- Slower performance compared to mypy, especially on larger codebases
- Less widespread adoption and community support
- More complex setup and configuration process
Code Comparison
mypy:
def greet(name: str) -> str:
return f"Hello, {name}!"
print(greet("World"))
pytype:
def greet(name):
return f"Hello, {name}!"
print(greet("World"))
In this example, mypy requires explicit type annotations, while pytype can infer types without annotations. However, pytype's inference may not always be as precise as explicit annotations.
Both tools aim to improve code quality and catch type-related errors, but they differ in their approaches and trade-offs. mypy is generally faster and more widely adopted, while pytype offers more advanced type inference capabilities. The choice between them often depends on specific project requirements and team preferences.
flake8 is a python tool that glues together pycodestyle, pyflakes, mccabe, and third-party plugins to check the style and quality of some python code.
Pros of flake8
- Faster execution time for code analysis
- Broader scope of linting, covering style and some logical errors
- Easier to set up and integrate into existing projects
Cons of flake8
- Less comprehensive type checking capabilities
- Limited ability to catch complex logical errors
- Fewer customization options for advanced users
Code Comparison
mypy:
def greet(name: str) -> str:
return f"Hello, {name}!"
result: str = greet(42) # Type error
flake8:
def greet(name):
return f"Hello, {name}!"
result = greet(42) # No error detected
mypy would catch the type mismatch in the function call, while flake8 would not detect this issue. However, flake8 might flag other style-related issues not shown in this example.
Both tools serve different purposes and can be used complementarily. mypy focuses on static type checking, while flake8 is primarily a style guide enforcement and basic error detection tool. Many developers use both in their Python projects to ensure code quality and catch different types of issues.
An extremely fast Python linter and code formatter, written in Rust.
Pros of Ruff
- Significantly faster performance due to being written in Rust
- Combines linting, formatting, and some type checking in a single tool
- Actively developed with frequent updates and new features
Cons of Ruff
- Less comprehensive type checking compared to Mypy
- Newer project with potentially less stability and community support
- May not cover all edge cases that Mypy handles for static type checking
Code Comparison
Mypy:
def greet(name: str) -> str:
return f"Hello, {name}!"
result: str = greet("Alice")
Ruff:
def greet(name: str) -> str:
return f"Hello, {name}!"
result = greet("Alice")
While both tools can work with type annotations, Mypy focuses on comprehensive static type checking, whereas Ruff combines linting, formatting, and basic type checking. Ruff may not require explicit type annotations in all cases where Mypy would, as shown in the result
variable declaration.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Mypy: Static Typing for Python
Got a question?
We are always happy to answer questions! Here are some good places to ask them:
- for general questions about Python typing, try typing discussions
- for anything you're curious about, try gitter chat
If you're just getting started, the documentation and type hints cheat sheet can also help answer questions.
If you think you've found a bug:
- check our common issues page
- search our issue tracker to see if it's already been reported
To report a bug or request an enhancement:
- report at our issue tracker
- if the issue is with a specific library or function, consider reporting it at typeshed tracker or the issue tracker for that library
To discuss a new type system feature:
- discuss at discuss.python.org
- there is also some historical discussion at the typing-sig mailing list and the python/typing repo
What is mypy?
Mypy is a static type checker for Python.
Type checkers help ensure that you're using variables and functions in your code correctly. With mypy, add type hints (PEP 484) to your Python programs, and mypy will warn you when you use those types incorrectly.
Python is a dynamic language, so usually you'll only see errors in your code when you attempt to run it. Mypy is a static checker, so it finds bugs in your programs without even running them!
Here is a small example to whet your appetite:
number = input("What is your favourite number?")
print("It is", number + 1) # error: Unsupported operand types for + ("str" and "int")
Adding type hints for mypy does not interfere with the way your program would otherwise run. Think of type hints as similar to comments! You can always use the Python interpreter to run your code, even if mypy reports errors.
Mypy is designed with gradual typing in mind. This means you can add type hints to your code base slowly and that you can always fall back to dynamic typing when static typing is not convenient.
Mypy has a powerful and easy-to-use type system, supporting features such as type inference, generics, callable types, tuple types, union types, structural subtyping and more. Using mypy will make your programs easier to understand, debug, and maintain.
See the documentation for more examples and information.
In particular, see:
Quick start
Mypy can be installed using pip:
python3 -m pip install -U mypy
If you want to run the latest version of the code, you can install from the repo directly:
python3 -m pip install -U git+https://github.com/python/mypy.git
Now you can type-check the statically typed parts of a program like this:
mypy PROGRAM
You can always use the Python interpreter to run your statically typed programs, even if mypy reports type errors:
python3 PROGRAM
If you are working with large code bases, you can run mypy in daemon mode, that will give much faster (often sub-second) incremental updates:
dmypy run -- PROGRAM
You can also try mypy in an online playground (developed by Yusuke Miyazaki).
Integrations
Mypy can be integrated into popular IDEs:
- VS Code: provides basic integration with mypy.
- Vim:
- Emacs: using Flycheck
- Sublime Text: SublimeLinter-contrib-mypy
- PyCharm: mypy plugin
- pre-commit: use pre-commit mirrors-mypy, although note by default this will limit mypy's ability to analyse your third party dependencies.
Web site and documentation
Additional information is available at the web site:
Jump straight to the documentation:
Follow along our changelog at:
https://mypy-lang.blogspot.com/
Contributing
Help in testing, development, documentation and other tasks is highly appreciated and useful to the project. There are tasks for contributors of all experience levels.
To get started with developing mypy, see CONTRIBUTING.md.
Mypyc and compiled version of mypy
Mypyc uses Python type hints to compile Python modules to faster C extensions. Mypy is itself compiled using mypyc: this makes mypy approximately 4 times faster than if interpreted!
To install an interpreted mypy instead, use:
python3 -m pip install --no-binary mypy -U mypy
To use a compiled version of a development version of mypy, directly install a binary from https://github.com/mypyc/mypy_mypyc-wheels/releases/latest.
To contribute to the mypyc project, check out the issue tracker at https://github.com/mypyc/mypyc
Top Related Projects
Static Type Checker for Python
It's not just a linter that annoys you!
Performant type-checking for python.
A static type analyzer for Python code
flake8 is a python tool that glues together pycodestyle, pyflakes, mccabe, and third-party plugins to check the style and quality of some python code.
An extremely fast Python linter and code formatter, written in Rust.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot