django-stubs VS pytype

Compare django-stubs vs pytype and see what are their differences.

InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
django-stubs pytype
7 21
1,462 4,602
1.8% 1.8%
9.6 9.8
4 days ago 11 days ago
Python Python
MIT License GNU General Public License v3.0 or later
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

django-stubs

Posts with mentions or reviews of django-stubs. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-10-17.
  • Mypy 1.6 Released
    5 projects | news.ycombinator.com | 17 Oct 2023
    Pyright doesn't work with Django, as Django's so dynamic that it requires a plugin to infer all types correctly. Sadly, even mypy with plugins is a mess to get set up in vscode, especially if you want it to use the same config as you use for ci checks from the command line.

    We use mypy + [django-stubs](https://github.com/typeddjango/django-stubs) (in a huge Django + drf project at day job) which includes a plugin for mypy allowing it to recognize all reverse relations and manager methods. Mypy is still really rough around the edges. The cli args are poorly documented, and how they correspond to declarations in a mypy.ini / pyproject.toml is mysterious. Match-statements still have bugs even a year after release. Exclusion of untyped / partially typed files and packages we've had to solve with grep filtering mypy's output for our whitelisted set of files, as it's been unable to separate properly between errors you care about (in your own codebase) and errors in others code (dependencies, untypable dynamic python packages etc).

    The largest issue IMO is that mypy tried to adapt a java / OOP style way of type system onto python, instead of recognizing the language's real power within duck typing and passing structural types around. Typescript chose the right approach here, modelling javascript the way it is actually written, favoring structural over nominal typing, instead of the archaic and now left-behind way of Java-style OOP that has influenced mypy.

    There was a recently accepted PEP which allowed for limited dataclass transforms, enough to cover the @attr.s usecase for both mypy and pyright, but nowhere near expressive enough to cover django's models and ORM sadly. It's probably impossible / undesirable to allow for such rich plugins, so i see the future for proper pluginless typing to be more akin to how pydantic / normal dataclasses solve typing, by starting with a specification of the types, deriving its runtime implementation, instead of plugins having to reverse the type representation of a custom DSL.

  • Boring Python: Code Quality
    14 projects | news.ycombinator.com | 20 Dec 2022
    You can annotate the manager and get some typing help in the editor. And there’s django-stubs which helps a little when running mypy. It’s not as good as pycharm though.

    https://github.com/typeddjango/django-stubs/tree/master

  • Python 3.11.0 final is now available
    11 projects | news.ycombinator.com | 25 Oct 2022
    > Yes, there are type stubs for these libraries but they’re either forced to be more strict, preventing use of dynamism, or opt for being less strict but allowing you to use all the library features, at the cost of safety.

    There are type stubs for Django that somewhat avoid these compromises: https://github.com/typeddjango/django-stubs

    To be able to do this they have to use a Mypy plugin though. And even then it's still far from perfect.

  • Welcome to hassle free coding
    4 projects | /r/ProgrammerHumor | 28 May 2022
  • Is Rust Web Yet?
    14 projects | news.ycombinator.com | 16 Apr 2022
    Mypy together with this plug-in gives you typing for django. https://github.com/TypedDjango/django-stubs
  • Django projects with type hints?
    1 project | /r/django | 13 Jan 2022
    Have you looked at stubs for Django?
  • Neovim + Django - LSP config
    1 project | /r/neovim | 22 Jun 2021

pytype

Posts with mentions or reviews of pytype. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-04-27.
  • Google lays off its Python team
    3 projects | news.ycombinator.com | 27 Apr 2024
    it's open source! check out https://github.com/google/pytype and https://github.com/google/pytype/blob/main/docs/developers/t... for more on the multi-file runner
  • Enhance Your Project Quality with These Top Python Libraries
    16 projects | dev.to | 18 Mar 2024
    Pytype checks and infers types for your Python code - without requiring type annotations. Pytype can catch type errors in your Python code before you even run it.
  • A Tale of Two Kitchens - Hypermodernizing Your Python Code Base
    31 projects | dev.to | 12 Nov 2023
    Pyre from Meta, pyright from Microsoft and PyType from Google provide additional assistance. They can 'infer' types based on code flow and existing types within the code.
  • Mypy 1.6 Released
    5 projects | news.ycombinator.com | 17 Oct 2023
    we've written a little bit about what pytype does differently here: https://google.github.io/pytype/

    our main focus is to be able to work with unannotated and partially-annotated code, and treat it on par with fully annotated code.

  • Mypy 1.5 Released
    1 project | news.ycombinator.com | 10 Aug 2023
    So, I tried out pytype the other day, and it was a not a good experience. It doesn't support PEP 420 (implicit namespace packages), which means you have to litter __init__.py files everywhere, or it will create filename collisions. See https://github.com/google/pytype/issues/198 for more information. I've since started testing out pyre.
  • Writing Python like it's Rust
    10 projects | news.ycombinator.com | 21 May 2023
    What is the smart money doing for type checking in Python? I've used mypy which seems to work well but is incredibly slow (3-4s to update linting after I change code). I've tried pylance type checking in VS Code, which seems to work well + fast but is less clear and comprehensive than mypy. I've also seen projects like pytype [1] and pyre [2] used by Google/Meta, but people say those tools don't really make sense to use unless you're an engineer for those companies.

    Am just curious if mypy is really the best option right now?

    [1] https://github.com/google/pytype

  • PyMEL's new type stubs
    1 project | dev.to | 7 Apr 2023
    At Luma, we're using mypy to check nearly our entire code-base, including our Maya-related code, thanks to these latest changes. Fully adopting mypy (or an alternative like pytype) is no small feat, but working within a fully type-annotated code base with a type checker to enforce accuracy is like coding in a higher plane of existence: fewer bugs, easier code navigation, faster dev onboarding, easier refactoring, and dramatically increased confidence about every change. I wrote about some deeper insights in these posts.
  • The Python Paradox
    7 projects | news.ycombinator.com | 26 Jan 2023
    Check out https://github.com/google/pytype
  • Forma: An efficient vector-graphics renderer
    7 projects | news.ycombinator.com | 16 Dec 2022
    i work on https://github.com/google/pytype which is largely developed internally and then pushed to github every few days. the github commits are associated with the team's personal github accounts. pytype is not an "official google product" insofar as the open source version is presented as is without official google support, but it is "production code" in the sense that it is very much used extensively within google.
  • Ruff – an fast Python Linter written in Rust
    6 projects | news.ycombinator.com | 31 Aug 2022
    pytype dev here - thanks for the kind words :) whole-program analysis on unannotated or partially-annotated code is our particular focus, but there's surprisingly little dark PLT magic involved; in particular you don't need to be an academic type theory wizard to understand how it works. our developer docs[1] have more info, but at a high level we have an interpreter that virtually executes python bytecode, tracking types where the cpython interpreter would have tracked values.

    it's worth exploring some of the other type checkers as well, since they make different tradeoffs - in particular, microsoft's pyright[2] (written in typescript!) can run incrementally within vscode, and tends to add new and experimentally proposed typing PEPs faster than we do.

    [1] https://github.com/google/pytype/blob/main/docs/developers/i...

What are some alternatives?

When comparing django-stubs and pytype you can also consider the following projects:

strawberry - A GraphQL library for Python that leverages type annotations 🍓

mypy - Optional static typing for Python

phantom-types - Phantom types for Python.

pyright - Static Type Checker for Python

pandas-stubs - Pandas type stubs. Helps you type-check your code.

pyre-check - Performant type-checking for python.

lagom - 📦 Autowiring dependency injection container for python 3

pyannotate - Auto-generate PEP-484 annotations

pandas-stubs - Public type stubs for pandas

pyanalyze - A Python type checker

returns - Make your functions return something meaningful, typed, and safe!

ruff - An extremely fast Python linter and code formatter, written in Rust.