A curated list with Github stars and forks stats based on awesome awesome-python
Inspired by fucking-awesome-go.
- Awesome Python
- Admin Panels
- Algorithms and Design Patterns
- ASGI Servers
- Asynchronous Programming
- Audio
- Authentication
- Build Tools
- Built-in Classes Enhancement
- Caching
- ChatOps Tools
- CMS
- Code Analysis
- Command-line Interface Development
- Command-line Tools
- Compatibility
- Computer Vision
- Concurrency and Parallelism
- Configuration
- Cryptography
- Data Analysis
- Data Validation
- Data Visualization
- Database Drivers
- Database
- Date and Time
- Debugging Tools
- Deep Learning
- DevOps Tools
- Distributed Computing
- Distribution
- Documentation
- Downloader
- E-commerce
- Editor Plugins and IDEs
- Environment Management
- Files
- Foreign Function Interface
- Forms
- Functional Programming
- Game Development
- Geolocation
- GUI Development
- Hardware
- HTML Manipulation
- HTTP Clients
- Image Processing
- Implementations
- Interactive Interpreter
- Internationalization
- Job Scheduler
- Logging
- Machine Learning
- Miscellaneous
- Natural Language Processing
- Network Virtualization
- News Feed
- ORM
- Package Management
- Package Repositories
- Penetration testing
- Permissions
- Processes
- Recommender Systems
- Refactoring
- RESTful API
- Robotics
- RPC Servers
- Science
- Search
- Serialization
- Serverless Frameworks
- Shell
- Specific Formats Processing
- Static Site Generator
- Tagging
- Task Queues
- Template Engine
- Testing
- Text Processing
- Third-party APIs
- URL Manipulation
- Video
- Web Asset Management
- Web Content Extracting
- Web Crawling
- Web Frameworks
- WebSocket
- WSGI Servers
- Resources
- Contributing
Libraries for administrative interfaces.
- ajenti - ⭐ 7157 🍴 832 - The admin panel your servers deserve.
- 🌎 django-grappelli - A jazzy skin for the Django Admin-Interface.
- django-jet - ⭐ 3445 🍴 786 - Modern responsive template for the Django admin interface with improved functionality.
- 🌎 django-suit - Alternative Django Admin-Interface (free only for Non-commercial use).
- django-xadmin - ⭐ 4709 🍴 1428 - Drop-in replacement of Django admin comes with lots of goodies.
- flask-admin - ⭐ 5409 🍴 1548 - Simple and extensible administrative interface framework for Flask.
- flower - ⭐ 5764 🍴 1022 - Real-time monitor and web admin for Celery.
- jet-bridge - ⭐ 1415 🍴 136 - Admin panel framework for any application with nice UI (ex Jet Django)
- wooey - ⭐ 1973 🍴 187 - A Django app which creates automatic web UIs for Python scripts.
Python implementation of data structures, algorithms and design patterns. Also see awesome-algorithms.
- Algorithms
- algorithms - ⭐ 22740 🍴 4501 - Minimal examples of data structures and algorithms.
- python-ds - ⭐ 2141 🍴 540 - A collection of data structure and algorithms for coding interviews.
- sortedcontainers - ⭐ 2985 🍴 195 - Fast and pure-Python implementation of sorted collections.
- TheAlgorithms - ⭐ 160888 🍴 40767 - All Algorithms implemented in Python.
- Design Patterns
- PyPattyrn - ⭐ 2015 🍴 143 - A simple yet effective library for implementing common design patterns.
- python-patterns - ⭐ 37686 🍴 6835 - A collection of design patterns in Python.
- transitions - ⭐ 4939 🍴 514 - A lightweight, object-oriented finite state machine implementation.
ASGI-compatible web servers.
- daphne - ⭐ 2050 🍴 242 - A HTTP, HTTP2 and WebSocket protocol server for ASGI and ASGI-HTTP.
- uvicorn - ⭐ 6752 🍴 596 - A lightning-fast ASGI server implementation, using uvloop and httptools.
- 🌎 asyncio - (Python standard library) Asynchronous I/O, event loop, coroutines and tasks.
- trio - ⭐ 5438 🍴 304 - A friendly library for async concurrency and I/O.
- 🌎 Twisted - An event-driven networking engine.
- uvloop - ⭐ 9432 🍴 554 - Ultra fast asyncio event loop.
Libraries for manipulating audio and its metadata.
- Audio
- audioread - ⭐ 442 🍴 107 - Cross-library (GStreamer + Core Audio + MAD + FFmpeg) audio decoding.
- dejavu - ⭐ 6081 🍴 1405 - Audio fingerprinting and recognition.
- kapre - ⭐ 892 🍴 146 - Keras Audio Preprocessors
- librosa - ⭐ 6052 🍴 888 - Python library for audio and music analysis
- matchering - ⭐ 994 🍴 132 - A library for automated reference audio mastering.
- 🌎 mingus - An advanced music theory and notation package with MIDI file and playback support.
- pyAudioAnalysis - ⭐ 5352 🍴 1150 - Audio feature extraction, classification, segmentation and applications.
- pydub - ⭐ 7435 🍴 952 - Manipulate audio with a simple and easy high level interface.
- TimeSide - ⭐ 351 🍴 62 - Open web audio processing framework.
- Metadata
- beets - ⭐ 11754 🍴 1808 - A music library manager and MusicBrainz tagger.
- eyeD3 - ⭐ 481 🍴 58 - A tool for working with audio files, specifically MP3 files containing ID3 metadata.
- mutagen - ⭐ 1293 🍴 143 - A Python module to handle audio metadata.
- tinytag - ⭐ 607 🍴 100 - A library for reading music meta data of MP3, OGG, FLAC and Wave files.
Libraries for implementing authentications schemes.
- OAuth
- authlib - ⭐ 3841 🍴 377 - JavaScript Object Signing and Encryption draft implementation.
- django-allauth - ⭐ 8066 🍴 2819 - Authentication app for Django that "just works."
- django-oauth-toolkit - ⭐ 2855 🍴 751 - OAuth 2 goodies for Django.
- oauthlib - ⭐ 2609 🍴 488 - A generic and thorough implementation of the OAuth request-signing logic.
- python-oauth2 - ⭐ 2982 🍴 1046 - A fully tested, abstract interface to creating OAuth clients and servers.
- python-social-auth - ⭐ 2834 🍴 1121 - An easy-to-setup social authentication mechanism.
- JWT
- pyjwt - ⭐ 4633 🍴 637 - JSON Web Token implementation in Python.
- python-jose - ⭐ 1321 🍴 226 - A JOSE implementation in Python.
- python-jwt - ⭐ 213 🍴 27 - A module for generating and verifying JSON Web Tokens.
Compile software from source code.
- 🌎 BitBake - A make-like build tool for embedded Linux.
- 🌎 buildout - A build system for creating, assembling and deploying applications from multiple parts.
- PlatformIO - ⭐ 6886 🍴 768 - A console tool to build code with different development platforms.
- pybuilder - ⭐ 1555 🍴 257 - A continuous build tool written in pure Python.
- 🌎 SCons - A software construction tool.
Libraries for enhancing Python built-in classes.
- attrs - ⭐ 4826 🍴 343 - Replacement for
__init__
,__eq__
,__repr__
, etc. boilerplate in class definitions. - bidict - ⭐ 1310 🍴 57 - Efficient, Pythonic bidirectional map data structures and related functionality..
- Box - ⭐ 2231 🍴 104 - Python dictionaries with advanced dot notation access.
- 🌎 dataclasses - (Python standard library) Data classes.
- DottedDict - ⭐ 168 🍴 25 - A library that provides a method of accessing lists and dicts with a dotted path notation.
Content Management Systems.
- 🌎 django-cms - An Open source enterprise CMS based on the Django.
- feincms - ⭐ 870 🍴 229 - One of the most advanced Content Management Systems built on Django.
- indico - ⭐ 1502 🍴 371 - A feature-rich event management system, made @ CERN.
- Kotti - ⭐ 401 🍴 116 - A high-level, Pythonic web application framework built on Pyramid.
- mezzanine - ⭐ 4637 🍴 1636 - A powerful, consistent, and flexible content management platform.
- 🌎 plone - A CMS built on top of the open source application server Zope.
- quokka - ⭐ 2227 🍴 457 - Flexible, extensible, small CMS powered by Flask and MongoDB.
- 🌎 wagtail - A Django content management system.
Libraries for caching data.
- beaker - ⭐ 506 🍴 142 - A WSGI middleware for sessions and caching.
- django-cache-machine - ⭐ 859 🍴 162 - Automatic caching and invalidation for Django models.
- django-cacheops - ⭐ 1862 🍴 218 - A slick ORM cache with automatic granular event-driven invalidation.
- 🌎 dogpile.cache - dogpile.cache is next generation replacement for Beaker made by same authors.
- 🌎 HermesCache - Python caching library with tag-based invalidation and dogpile effect prevention.
- pylibmc - ⭐ 469 🍴 134 - A Python wrapper around the libmemcached interface.
- 🌎 python-diskcache - SQLite and file backed cache backend with faster lookups than memcached and redis.
Libraries for chatbot development.
- errbot - ⭐ 2946 🍴 605 - The easiest and most popular chatbot to implement ChatOps.
Tools of static analysis, linters and code quality checkers. Also see awesome-static-analysis.
- Code Analysis
- coala - ⭐ 3477 🍴 1346 - Language independent and easily extendable code analysis application.
- code2flow - ⭐ 3292 🍴 246 - Turn your Python and JavaScript code into DOT flowcharts.
- prospector - ⭐ 1830 🍴 170 - A tool to analyse Python code.
- pycallgraph - ⭐ 1742 🍴 314 - A library that visualises the flow (call graph) of your Python application.
- vulture - ⭐ 2634 🍴 125 - A tool for finding and analysing dead Python code.
- Code Linters
- 🌎 flake8 - A wrapper around
pycodestyle
,pyflakes
and McCabe.- awesome-flake8-extensions - ⭐ 1117 🍴 43
- pylama - ⭐ 1003 🍴 102 - A code audit tool for Python and JavaScript.
- 🌎 pylint - A fully customizable source code analyzer.
- wemake-python-styleguide - ⭐ 2249 🍴 376 - The strictest and most opinionated python linter ever.
- 🌎 flake8 - A wrapper around
- Code Formatters
- Static Type Checkers, also see awesome-python-typing
- 🌎 mypy - Check variable types during compile time.
- pyre-check - ⭐ 6402 🍴 428 - Performant type checking.
- typeshed - ⭐ 3682 🍴 1563 - Collection of library stubs for Python, with static types.
- Static Type Annotations Generators
- MonkeyType - ⭐ 4297 🍴 159 - A system for Python that generates static type annotations by collecting runtime types.
- pyannotate - ⭐ 1389 🍴 61 - Auto-generate PEP-484 annotations.
- pytype - ⭐ 4274 🍴 277 - Pytype checks and infers types for Python code - without requiring type annotations.
Libraries for building command-line applications.
- Command-line Application Development
- 🌎 cement - CLI Application Framework for Python.
- 🌎 click - A package for creating beautiful command line interfaces in a composable way.
- 🌎 cliff - A framework for creating command-line programs with multi-level commands.
- 🌎 docopt - Pythonic command line arguments parser.
- python-fire - ⭐ 24846 🍴 1405 - A library for creating command line interfaces from absolutely any Python object.
- python-prompt-toolkit - ⭐ 8451 🍴 687 - A library for building powerful interactive command lines.
- Terminal Rendering
- alive-progress - ⭐ 4535 🍴 183 - A new kind of Progress Bar, with real-time throughput, eta and very cool animations.
- asciimatics - ⭐ 3354 🍴 242 - A package to create full-screen text UIs (from interactive forms to ASCII animations).
- bashplotlib - ⭐ 1746 🍴 135 - Making basic plots in the terminal.
- 🌎 colorama - Cross-platform colored terminal text.
- rich - ⭐ 43909 🍴 1592 - Python library for rich text and beautiful formatting in the terminal. Also provides a great
RichHandler
log handler. - tqdm - ⭐ 25235 🍴 1284 - Fast, extensible progress bar for loops and CLI.
Useful CLI-based tools for productivity.
- Productivity Tools
- copier - ⭐ 1147 🍴 128 - A library and command-line utility for rendering projects templates.
- cookiecutter - ⭐ 19920 🍴 1862 - A command-line utility that creates projects from cookiecutters (project templates).
- doitlive - ⭐ 3306 🍴 100 - A tool for live presentations in the terminal.
- howdoi - ⭐ 10134 🍴 866 - Instant coding answers via the command line.
- Invoke - ⭐ 4012 🍴 352 - A tool for managing shell-oriented subprocesses and organizing executable Python code into CLI-invokable tasks.
- PathPicker - ⭐ 4931 🍴 311 - Select files out of bash output.
- percol - ⭐ 3206 🍴 148 - Adds flavor of interactive selection to the traditional pipe concept on UNIX.
- thefuck - ⭐ 78474 🍴 3386 - Correcting your previous console command.
- tmuxp - ⭐ 3727 🍴 228 - A tmux session manager.
- try - ⭐ 680 🍴 41 - A dead simple CLI to try out python packages - it's never been easier.
- CLI Enhancements
- httpie - ⭐ 28467 🍴 3789 - A command line HTTP client, a user-friendly cURL replacement.
- iredis - ⭐ 2319 🍴 93 - Redis CLI with autocompletion and syntax highlighting.
- kube-shell - ⭐ 2306 🍴 176 - An integrated shell for working with the Kubernetes CLI.
- litecli - ⭐ 1851 🍴 65 - SQLite CLI with autocompletion and syntax highlighting.
- mycli - ⭐ 10970 🍴 650 - MySQL CLI with autocompletion and syntax highlighting.
- pgcli - ⭐ 11172 🍴 518 - PostgreSQL CLI with autocompletion and syntax highlighting.
- saws - ⭐ 5148 🍴 287 - A Supercharged aws-cli.
Libraries for migrating from Python 2 to 3.
- 🌎 python-future - The missing compatibility layer between Python 2 and Python 3.
- modernize - ⭐ 318 🍴 55 - Modernizes Python code for eventual Python 3 migration.
- 🌎 six - Python 2 and 3 compatibility utilities.
Libraries for Computer Vision.
- EasyOCR - ⭐ 18816 🍴 2669 - Ready-to-use OCR with 40+ languages supported.
- Face Recognition - ⭐ 48796 🍴 13016 - Simple facial recognition library.
- Kornia - ⭐ 8362 🍴 851 - Open Source Differentiable Computer Vision Library for PyTorch.
- 🌎 OpenCV - Open Source Computer Vision Library.
- pytesseract - ⭐ 4944 🍴 661 - A wrapper for Google Tesseract OCR.
- SimpleCV - ⭐ 2616 🍴 814 - An open source framework for building computer vision applications.
- tesserocr - ⭐ 1813 🍴 251 - Another simple, Pillow-friendly, wrapper around the
tesseract-ocr
API for OCR.
Libraries for concurrent and parallel execution. Also see awesome-asyncio.
- 🌎 concurrent.futures - (Python standard library) A high-level interface for asynchronously executing callables.
- 🌎 eventlet - Asynchronous framework with WSGI support.
- gevent - ⭐ 1492 🍴 230 - A coroutine-based Python networking library that uses greenlet.
- 🌎 multiprocessing - (Python standard library) Process-based parallelism.
- scoop - ⭐ 595 🍴 89 - Scalable Concurrent Operations in Python.
- uvloop - ⭐ 9432 🍴 554 - Ultra fast implementation of
asyncio
event loop on top oflibuv
.
Libraries for storing and parsing configuration options.
- configobj - ⭐ 295 🍴 70 - INI file parser with validation.
- 🌎 configparser - (Python standard library) INI file parser.
- hydra - ⭐ 7315 🍴 594 - Hydra is a framework for elegantly configuring complex applications.
- 🌎 profig - Config from multiple formats with value conversion.
- python-decouple - ⭐ 2460 🍴 178 - Strict separation of settings from code.
- 🌎 cryptography - A package designed to expose cryptographic primitives and recipes to Python developers.
- paramiko - ⭐ 8410 🍴 1933 - The leading native Python SSHv2 protocol library.
- 🌎 passlib - Secure password storage/hashing library, very high level.
- pynacl - ⭐ 982 🍴 225 - Python binding to the Networking and Cryptography (NaCl) library.
Libraries for data analyzing.
- AWS Data Wrangler - ⭐ 3526 🍴 624 - Pandas on AWS.
- Blaze - ⭐ 3154 🍴 390 - NumPy and Pandas interface to Big Data.
- Open Mining - ⭐ 1230 🍴 241 - Business Intelligence (BI) in Pandas interface.
- Optimus - ⭐ 1389 🍴 233 - Agile Data Science Workflows made easy with PySpark.
- 🌎 Orange - Data mining, data visualization, analysis and machine learning through visual programming or scripts.
- 🌎 Pandas - A library providing high-performance, easy-to-use data structures and data analysis tools.
Libraries for validating data. Used for forms in many cases.
- Cerberus - ⭐ 2995 🍴 237 - A lightweight and extensible data validation library.
- 🌎 colander - Validating and deserializing data obtained via XML, JSON, an HTML form post.
- jsonschema - ⭐ 4186 🍴 563 - An implementation of JSON Schema for Python.
- schema - ⭐ 2762 🍴 197 - A library for validating Python data structures.
- Schematics - ⭐ 2560 🍴 291 - Data Structure Validation.
- valideer - ⭐ 262 🍴 24 - Lightweight extensible data validation and adaptation library.
- voluptuous - ⭐ 1773 🍴 208 - A Python data validation library.
Libraries for visualizing data. Also see awesome-javascript.
- Altair - ⭐ 8368 🍴 737 - Declarative statistical visualization library for Python.
- Bokeh - ⭐ 17747 🍴 4112 - Interactive Web Plotting for Python.
- bqplot - ⭐ 3451 🍴 474 - Interactive Plotting Library for the Jupyter Notebook
- Cartopy - ⭐ 1244 🍴 348 - A cartographic python library with matplotlib support
- 🌎 Dash - Built on top of Flask, React and Plotly aimed at analytical web applications.
- awesome-dash - ⭐ 1883 🍴 243
- diagrams - ⭐ 30222 🍴 1918 - Diagram as Code.
- 🌎 Matplotlib - A Python 2D plotting library.
- plotnine - ⭐ 3510 🍴 203 - A grammar of graphics for Python based on ggplot2.
- 🌎 Pygal - A Python SVG Charts Creator.
- 🌎 PyGraphviz - Python interface to Graphviz.
- 🌎 PyQtGraph - Interactive and realtime 2D/3D/Image plotting and science/engineering widgets.
- Seaborn - ⭐ 10907 🍴 1738 - Statistical data visualization using Matplotlib.
- VisPy - ⭐ 3084 🍴 606 - High-performance scientific visualization based on OpenGL.
Databases implemented in Python.
- pickleDB - ⭐ 795 🍴 123 - A simple and lightweight key-value store for Python.
- tinydb - ⭐ 5967 🍴 510 - A tiny, document-oriented database.
- ZODB - ⭐ 614 🍴 87 - A native object database for Python. A key-value and object graph database.
Libraries for connecting and operating databases.
- MySQL - awesome-mysql
- mysqlclient - ⭐ 2273 🍴 412 - MySQL connector with Python 3 support (mysql-python fork).
- PyMySQL - ⭐ 7328 🍴 1409 - A pure Python MySQL driver compatible to mysql-python.
- PostgreSQL - awesome-postgres
- 🌎 psycopg2 - The most popular PostgreSQL adapter for Python.
- queries - ⭐ 258 🍴 34 - A wrapper of the psycopg2 library for interacting with PostgreSQL.
- Other Relational Databases
- 🌎 pymssql - A simple database interface to Microsoft SQL Server.
- SuperSQLite - ⭐ 713 🍴 24 - A supercharged SQLite library built on top of apsw.
- NoSQL Databases
- cassandra-driver - ⭐ 1342 🍴 522 - The Python Driver for Apache Cassandra.
- happybase - ⭐ 603 🍴 165 - A developer-friendly library for Apache HBase.
- kafka-python - ⭐ 5231 🍴 1358 - The Python client for Apache Kafka.
- 🌎 py2neo - A client library and toolkit for working with Neo4j.
- pymongo - ⭐ 3882 🍴 1116 - The official Python client for MongoDB.
- redis-py - ⭐ 11629 🍴 2386 - The Python client for Redis.
- Asynchronous Clients
- motor - ⭐ 2183 🍴 200 - The async Python driver for MongoDB.
Libraries for working with dates and times.
- 🌎 Arrow - A Python library that offers a sensible and human-friendly approach to creating, manipulating, formatting and converting dates, times and timestamps.
- Chronyk - ⭐ 341 🍴 16 - A Python 3 library for parsing human-written times and dates.
- dateutil - ⭐ 2095 🍴 439 - Extensions to the standard Python datetime module.
- delorean - ⭐ 1844 🍴 133 - A library for clearing up the inconvenient truths that arise dealing with datetimes.
- maya - ⭐ 3385 🍴 222 - Datetimes for Humans.
- moment - ⭐ 716 🍴 49 - A Python library for dealing with dates/times. Inspired by Moment.js.
- Pendulum - ⭐ 5519 🍴 336 - Python datetimes made easy.
- PyTime - ⭐ 151 🍴 26 - An easy-to-use Python module which aims to operate date/time/datetime by string.
- 🌎 pytz - World timezone definitions, modern and historical. Brings the tz database into Python.
- when.py - ⭐ 190 🍴 20 - Providing user-friendly functions to help perform common date and time actions.
Libraries for debugging code.
- pdb-like Debugger
- Tracing
- lptrace - ⭐ 691 🍴 42 - strace for Python programs.
- manhole - ⭐ 342 🍴 21 - Debugging UNIX socket connections and present the stacktraces for all threads and an interactive prompt.
- pyringe - ⭐ 1638 🍴 81 - Debugger capable of attaching to and injecting code into Python processes.
- python-hunter - ⭐ 739 🍴 43 - A flexible code tracing toolkit.
- Profiler
- line_profiler - ⭐ 3600 🍴 258 - Line-by-line profiling.
- memory_profiler - ⭐ 81 🍴 13 - Monitor Memory usage of Python code.
- profiling - ⭐ 2972 🍴 121 - An interactive Python profiler.
- py-spy - ⭐ 10589 🍴 376 - A sampling profiler for Python programs. Written in Rust.
- pyflame - ⭐ 2973 🍴 240 - A ptracing profiler For Python.
- vprof - ⭐ 3926 🍴 170 - Visual Python profiler.
- Others
- django-debug-toolbar - ⭐ 7564 🍴 1020 - Display various debug information for Django.
- django-devserver - ⭐ 1274 🍴 167 - A drop-in replacement for Django's runserver.
- flask-debugtoolbar - ⭐ 876 🍴 131 - A port of the django-debug-toolbar to flask.
- icecream - ⭐ 6848 🍴 143 - Inspect variables, expressions, and program execution with a single, simple function call.
- pyelftools - ⭐ 1701 🍴 486 - Parsing and analyzing ELF files and DWARF debugging information.
Frameworks for Neural Networks and Deep Learning. Also see awesome-deep-learning.
- caffe - ⭐ 33468 🍴 18994 - A fast open framework for deep learning..
- keras - ⭐ 58844 🍴 19379 - A high-level neural networks library and capable of running on top of either TensorFlow or Theano.
- mxnet - ⭐ 20486 🍴 6882 - A deep learning framework designed for both efficiency and flexibility.
- pytorch - ⭐ 68879 🍴 18847 - Tensors and Dynamic neural networks in Python with strong GPU acceleration.
- SerpentAI - ⭐ 6529 🍴 774 - Game agent framework. Use any video game as a deep learning sandbox.
- tensorflow - ⭐ 176201 🍴 88687 - The most popular Deep Learning framework created by Google.
- Theano - ⭐ 9756 🍴 2511 - A library for fast numerical computation.
Software and libraries for DevOps.
- Configuration Management
- ansible - ⭐ 57982 🍴 23510 - A radically simple IT automation platform.
- 🌎 cloudinit - A multi-distribution package that handles early initialization of a cloud instance.
- 🌎 OpenStack - Open source software for building private and public clouds.
- pyinfra - ⭐ 2350 🍴 306 - A versatile CLI tools and python libraries to automate infrastructure.
- saltstack - ⭐ 13353 🍴 5440 - Infrastructure automation and management system.
- SSH-style Deployment
- Process Management
- honcho - ⭐ 1534 🍴 143 - A Python clone of Foreman, for managing Procfile-based applications.
- supervisor - ⭐ 7830 🍴 1219 - Supervisor process control system for UNIX.
- Monitoring
- psutil - ⭐ 9402 🍴 1344 - A cross-platform process and system utilities module.
- Backup
- 🌎 BorgBackup - A deduplicating archiver with compression and encryption.
- Others
- 🌎 docker-compose - Fast, isolated development environments using Docker.
Frameworks and libraries for Distributed Computing.
- Batch Processing
- dask - ⭐ 11203 🍴 1633 - A flexible parallel computing library for analytic computing.
- luigi - ⭐ 16648 🍴 2376 - A module that helps you build complex pipelines of batch jobs.
- mrjob - ⭐ 2604 🍴 606 - Run MapReduce jobs on Hadoop or Amazon Web Services.
- 🌎 PySpark - Apache Spark Python API.
- Ray - ⭐ 26613 🍴 4606 - A system for parallel and distributed Python that unifies the machine learning ecosystem.
- Stream Processing
- faust - ⭐ 6572 🍴 551 - A stream processing library, porting the ideas from Kafka Streams to Python.
- streamparse - ⭐ 1482 🍴 220 - Run Python code against real-time streams of data via Apache Storm.
Libraries to create packaged executables for release distribution.
- dh-virtualenv - ⭐ 1571 🍴 191 - Build and distribute a virtualenv as a Debian package.
- 🌎 Nuitka - Compile scripts, modules, packages to an executable or extension module.
- 🌎 py2app - Freezes Python scripts (Mac OS X).
- 🌎 py2exe - Freezes Python scripts (Windows).
- pyarmor - ⭐ 2327 🍴 234 - A tool used to obfuscate python scripts, bind obfuscated scripts to fixed machine or expire obfuscated scripts.
- PyInstaller - ⭐ 10446 🍴 1892 - Converts Python programs into stand-alone executables (cross-platform).
- 🌎 pynsist - A tool to build Windows installers, installers bundle Python itself.
- shiv - ⭐ 1609 🍴 85 - A command line utility for building fully self-contained zipapps (PEP 441), but with all their dependencies included.
Libraries for generating project documentation.
- sphinx - ⭐ 5521 🍴 1947 - Python Documentation generator.
- awesome-sphinxdoc - ⭐ 872 🍴 70
- pdoc - ⭐ 1588 🍴 177 - Epydoc replacement to auto generate API documentation for Python libraries.
- pycco - ⭐ 827 🍴 148 - The literate-programming-style documentation generator.
Libraries for downloading.
- akshare - ⭐ 6813 🍴 1504 - A financial data interface library, built for human beings!
- s3cmd - ⭐ 4208 🍴 898 - A command line tool for managing Amazon S3 and CloudFront.
- s4cmd - ⭐ 1301 🍴 207 - Super S3 command line tool, good for higher performance.
- 🌎 you-get - A YouTube/Youku/Niconico video downloader written in Python 3.
- 🌎 youtube-dl - A small command-line program to download videos from YouTube.
Frameworks and libraries for e-commerce and payments.
- alipay - ⭐ 325 🍴 98 - Unofficial Alipay API for Python.
- Cartridge - ⭐ 692 🍴 302 - A shopping cart app built using the Mezzanine.
- 🌎 django-oscar - An open-source e-commerce framework for Django.
- django-shop - ⭐ 3018 🍴 1019 - A Django based shop system.
- forex-python - ⭐ 586 🍴 176 - Foreign exchange rates, Bitcoin price index and currency conversion.
- merchant - ⭐ 1013 🍴 175 - A Django app to accept payments from various payment processors.
- money - ⭐ 224 🍴 30 -
Money
class with optional CLDR-backed locale-aware formatting and an extensible currency exchange. - python-currencies - ⭐ 69 🍴 12 - Display money format and its filthy currencies.
- 🌎 saleor - An e-commerce storefront for Django.
- 🌎 shoop - An open source E-Commerce platform based on Django.
- Emacs
- elpy - ⭐ 1848 🍴 255 - Emacs Python Development Environment.
- Sublime Text
- anaconda - ⭐ 2192 🍴 264 - Anaconda turns your Sublime Text 3 in a full featured Python development IDE.
- SublimeJEDI - ⭐ 940 🍴 113 - A Sublime Text plugin to the awesome auto-complete library Jedi.
- Vim
- jedi-vim - ⭐ 5185 🍴 377 - Vim bindings for the Jedi auto-completion library for Python.
- python-mode - ⭐ 5417 🍴 893 - An all in one plugin for turning Vim into a Python IDE.
- YouCompleteMe - ⭐ 24841 🍴 2821 - Includes Jedi-based completion engine for Python.
- Visual Studio
- PTVS - ⭐ 2466 🍴 700 - Python Tools for Visual Studio.
- Visual Studio Code
- 🌎 Python - The official VSCode extension with rich support for Python.
- IDE
Libraries for sending and parsing email.
- Mail Servers
- Clients
- Others
Libraries for Python version and virtual environment management.
- pyenv - ⭐ 32557 🍴 2819 - Simple Python version management.
- virtualenv - ⭐ 4501 🍴 1014 - A tool to create isolated Python environments.
Libraries for file manipulation and MIME type detection.
- 🌎 mimetypes - (Python standard library) Map filenames to MIME types.
- path.py - ⭐ 1057 🍴 141 - A module wrapper for os.path.
- 🌎 pathlib - (Python standard library) An cross-platform, object-oriented path library.
- PyFilesystem2 - ⭐ 1867 🍴 176 - Python's filesystem abstraction layer.
- python-magic - ⭐ 2361 🍴 264 - A Python interface to the libmagic file type identification library.
- Unipath - ⭐ 514 🍴 39 - An object-oriented approach to file/directory operations.
- watchdog - ⭐ 5886 🍴 680 - API and shell utilities to monitor file system events.
Libraries for providing foreign function interface.
- 🌎 cffi - Foreign Function Interface for Python calling C code.
- 🌎 ctypes - (Python standard library) Foreign Function Interface for Python calling C code.
- 🌎 PyCUDA - A Python wrapper for Nvidia's CUDA API.
- 🌎 SWIG - Simplified Wrapper and Interface Generator.
Libraries for working with forms.
- Deform - ⭐ 398 🍴 162 - Python HTML form generation library influenced by the formish form generation library.
- django-bootstrap3 - ⭐ 2317 🍴 694 - Bootstrap 3 integration with Django.
- django-bootstrap4 - ⭐ 1002 🍴 257 - Bootstrap 4 integration with Django.
- django-crispy-forms - ⭐ 4739 🍴 733 - A Django app which lets you create beautiful forms in a very elegant and DRY way.
- django-remote-forms - ⭐ 222 🍴 113 - A platform independent Django form serializer.
- WTForms - ⭐ 1405 🍴 386 - A flexible forms validation and rendering library.
Functional Programming with Python.
- Coconut - ⭐ 3767 🍴 112 - A variant of Python built for simple, elegant, Pythonic functional programming.
- CyToolz - ⭐ 927 🍴 67 - Cython implementation of
Toolz
: High performance functional utilities. - fn.py - ⭐ 3301 🍴 200 - Functional programming in Python: implementation of missing features to enjoy FP.
- funcy - ⭐ 3104 🍴 141 - A fancy and practical functional tools.
- more-itertools - ⭐ 3124 🍴 251 - More routines for operating on iterables, beyond
itertools
. - returns - ⭐ 2827 🍴 98 - A set of type-safe monads, transformers, and composition utilities.
- Toolz - ⭐ 4280 🍴 251 - A collection of functional utilities for iterators, functions, and dictionaries.
Libraries for working with graphical user interface applications.
- 🌎 curses - Built-in wrapper for ncurses used to create terminal GUI applications.
- Eel - ⭐ 5709 🍴 558 - A library for making simple Electron-like offline HTML/JS GUI apps.
- enaml - ⭐ 1486 🍴 132 - Creating beautiful user-interfaces with Declarative Syntax like QML.
- Flexx - ⭐ 3139 🍴 262 - Flexx is a pure Python toolkit for creating GUI's, that uses web technology for its rendering.
- Gooey - ⭐ 17711 🍴 945 - Turn command line programs into a full GUI application with one line.
- 🌎 kivy - A library for creating NUI applications, running on Windows, Linux, Mac OS X, Android and iOS.
- pyglet - ⭐ 1529 🍴 268 - A cross-platform windowing and multimedia library for Python.
- 🌎 PyGObject - Python Bindings for GLib/GObject/GIO/GTK+ (GTK+3).
- 🌎 PyQt - Python bindings for the Qt cross-platform application and UI framework.
- PySimpleGUI - ⭐ 11811 🍴 1746 - Wrapper for tkinter, Qt, WxPython and Remi.
- pywebview - ⭐ 3664 🍴 477 - A lightweight cross-platform native wrapper around a webview component.
- 🌎 Tkinter - Tkinter is Python's de-facto standard GUI package.
- Toga - ⭐ 3542 🍴 598 - A Python native, OS native GUI toolkit.
- 🌎 urwid - A library for creating terminal GUI applications with strong support for widgets, events, rich colors, etc.
- 🌎 wxPython - A blending of the wxWidgets C++ class library with the Python.
- DearPyGui - ⭐ 10714 🍴 586 - A Simple GPU accelerated Python GUI framework
Libraries for working with GraphQL.
- graphene - ⭐ 7728 🍴 829 - GraphQL framework for Python.
- tartiflette-aiohttp - ⭐ 60 🍴 9 - An
aiohttp
-based wrapper for Tartiflette to expose GraphQL APIs over HTTP. - tartiflette-asgi - ⭐ 100 🍴 16 - ASGI support for the Tartiflette GraphQL engine.
- 🌎 tartiflette - SDL-first GraphQL engine implementation for Python 3.6+ and asyncio.
Awesome game development libraries.
- 🌎 Arcade - Arcade is a modern Python framework for crafting games with compelling graphics and sound.
- 🌎 Cocos2d - cocos2d is a framework for building 2D games, demos, and other graphical/interactive applications.
- 🌎 Harfang3D - Python framework for 3D, VR and game development.
- 🌎 Panda3D - 3D game engine developed by Disney.
- 🌎 Pygame - Pygame is a set of Python modules designed for writing games.
- 🌎 PyOgre - Python bindings for the Ogre 3D render engine, can be used for games, simulations, anything 3D.
- 🌎 PyOpenGL - Python ctypes bindings for OpenGL and it's related APIs.
- 🌎 PySDL2 - A ctypes based wrapper for the SDL2 library.
- 🌎 RenPy - A Visual Novel engine.
Libraries for geocoding addresses and working with latitudes and longitudes.
- django-countries - ⭐ 1289 🍴 257 - A Django app that provides a country field for models and forms.
- 🌎 GeoDjango - A world-class geographic web framework.
- GeoIP - ⭐ 232 🍴 63 - Python API for MaxMind GeoIP Legacy Database.
- geojson - ⭐ 823 🍴 118 - Python bindings and utilities for GeoJSON.
- geopy - ⭐ 4008 🍴 614 - Python Geocoding Toolbox.
- pygeoip - ⭐ 484 🍴 113 - Pure Python GeoIP API.
Libraries for working with HTML and XML.
- 🌎 BeautifulSoup - Providing Pythonic idioms for iterating, searching, and modifying HTML or XML.
- bleach - ⭐ 2528 🍴 253 - A whitelist-based HTML sanitization and text linkification library.
- 🌎 cssutils - A CSS library for Python.
- html5lib - ⭐ 1041 🍴 279 - A standards-compliant library for parsing and serializing HTML documents and fragments.
- 🌎 lxml - A very fast, easy-to-use and versatile library for handling HTML and XML.
- MarkupSafe - ⭐ 538 🍴 147 - Implements a XML/HTML/XHTML Markup safe string for Python.
- pyquery - ⭐ 2216 🍴 183 - A jQuery-like library for parsing HTML.
- untangle - ⭐ 597 🍴 83 - Converts XML documents to Python objects for easy access.
- 🌎 WeasyPrint - A visual rendering engine for HTML and CSS that can export to PDF.
- 🌎 xmldataset - Simple XML Parsing.
- xmltodict - ⭐ 5173 🍴 469 - Working with XML feel like you are working with JSON.
Libraries for working with HTTP.
- grequests - ⭐ 4272 🍴 334 - requests + gevent for asynchronous HTTP requests.
- httplib2 - ⭐ 469 🍴 196 - Comprehensive HTTP client library.
- httpx - ⭐ 10783 🍴 709 - A next generation HTTP client for Python.
- requests - ⭐ 49914 🍴 9140 - HTTP Requests for Humans.
- treq - ⭐ 556 🍴 142 - Python requests like API built on top of Twisted's HTTP client.
- urllib3 - ⭐ 3447 🍴 1080 - A HTTP library with thread-safe connection pooling, file post support, sanity friendly.
Libraries for programming with hardware.
- 🌎 ino - Command line toolkit for working with Arduino.
- keyboard - ⭐ 3439 🍴 406 - Hook and simulate global keyboard events on Windows and Linux.
- mouse - ⭐ 776 🍴 123 - Hook and simulate global mouse events on Windows and Linux.
- 🌎 Pingo - Pingo provides a uniform API to program devices like the Raspberry Pi, pcDuino, Intel Galileo, etc.
- PyUserInput - ⭐ 1066 🍴 248 - A module for cross-platform control of the mouse and keyboard.
- scapy - ⭐ 8986 🍴 1883 - A brilliant packet manipulation library.
- wifi - ⭐ 291 🍴 166 - A Python library and command line tool for working with WiFi on Linux.
Libraries for manipulating images.
- hmap - ⭐ 203 🍴 24 - Image histogram remapping.
- 🌎 imgSeek - A project for searching a collection of images using visual similarity.
- nude.py - ⭐ 914 🍴 134 - Nudity detection.
- pagan - ⭐ 297 🍴 43 - Retro identicon (Avatar) generation based on input string and hash.
- pillow - ⭐ 10982 🍴 2076 - Pillow is the friendly PIL fork.
- python-barcode - ⭐ 474 🍴 113 - Create barcodes in Python with no extra dependencies.
- 🌎 PyMatting - A library for alpha matting.
- python-qrcode - ⭐ 3761 🍴 600 - A pure Python QR Code generator.
- pywal - ⭐ 7370 🍴 293 - A tool that generates color schemes from images.
- pyvips - ⭐ 525 🍴 48 - A fast image processing library with low memory needs.
- Quads - ⭐ 1145 🍴 146 - Computer art based on quadtrees.
- 🌎 scikit-image - A Python library for (scientific) image processing.
- thumbor - ⭐ 9558 🍴 818 - A smart imaging service. It enables on-demand crop, re-sizing and flipping of images.
- wand - ⭐ 1295 🍴 195 - Python bindings for MagickWand, C API for ImageMagick.
Implementations of Python.
- CLPython - ⭐ 356 🍴 36 - Implementation of the Python programming language written in Common Lisp.
- CPython - ⭐ 54512 🍴 27255 - Default, most widely used implementation of the Python programming language written in C.
- 🌎 Cython - Optimizing Static Compiler for Python.
- Grumpy - ⭐ 10579 🍴 673 - More compiler than interpreter as more powerful CPython2.7 replacement (alpha).
- IronPython - ⭐ 2168 🍴 261 - Implementation of the Python programming language written in C#.
- 🌎 Jython - Implementation of Python programming language written in Java for the JVM.
- MicroPython - ⭐ 16880 🍴 6617 - A lean and efficient Python programming language implementation.
- 🌎 Numba - Python JIT compiler to LLVM aimed at scientific Python.
- PeachPy - ⭐ 1778 🍴 161 - x86-64 assembler embedded in Python.
- Pyjion - ⭐ 1579 🍴 132 - A JIT for Python based upon CoreCLR.
- 🌎 PyPy - A very fast and compliant implementation of the Python language.
- Pyston - ⭐ 4923 🍴 304 - A Python implementation using JIT techniques.
- Stackless Python - ⭐ 940 🍴 61 - An enhanced version of the Python programming language.
Interactive Python interpreters (REPL).
- bpython - ⭐ 2397 🍴 232 - A fancy interface to the Python interpreter.
- 🌎 Jupyter Notebook (IPython) - A rich toolkit to help you make the most out of using Python interactively.
- awesome-jupyter - ⭐ 3434 🍴 409
- ptpython - ⭐ 4789 🍴 265 - Advanced Python REPL built on top of the python-prompt-toolkit.
Libraries for working with i18n.
- 🌎 Babel - An internationalization library for Python.
- PyICU - ⭐ 130 🍴 50 - A wrapper of International Components for Unicode C++ library (ICU).
Libraries for scheduling jobs.
- 🌎 Airflow - Airflow is a platform to programmatically author, schedule and monitor workflows.
- 🌎 APScheduler - A light but powerful in-process task scheduler that lets you schedule functions.
- django-schedule - ⭐ 826 🍴 287 - A calendaring app for Django.
- 🌎 doit - A task runner and build tool.
- gunnery - ⭐ 753 🍴 77 - Multipurpose task execution tool for distributed systems with web-based interface.
- 🌎 Joblib - A set of tools to provide lightweight pipelining in Python.
- Plan - ⭐ 1170 🍴 96 - Writing crontab file in Python like a charm.
- Prefect - ⭐ 12331 🍴 1286 - A modern workflow orchestration framework that makes it easy to build, schedule and monitor robust data pipelines.
- schedule - ⭐ 10929 🍴 935 - Python job scheduling for humans.
- Spiff - ⭐ 1459 🍴 301 - A powerful workflow engine implemented in pure Python.
- 🌎 TaskFlow - A Python library that helps to make task execution easy, consistent and reliable.
Libraries for generating and working with logs.
- 🌎 logbook - Logging replacement for Python.
- 🌎 logging - (Python standard library) Logging facility for Python.
- loguru - ⭐ 15349 🍴 626 - Library which aims to bring enjoyable logging in Python.
- sentry-python - ⭐ 1566 🍴 394 - Sentry SDK for Python.
- 🌎 structlog - Structured logging made easy.
Libraries for Machine Learning. Also see awesome-machine-learning.
- gym - ⭐ 32370 🍴 8538 - A toolkit for developing and comparing reinforcement learning algorithms.
- H2O - ⭐ 6383 🍴 1984 - Open Source Fast Scalable Machine Learning Platform.
- Metrics - ⭐ 1594 🍴 453 - Machine learning evaluation metrics.
- NuPIC - ⭐ 6325 🍴 1583 - Numenta Platform for Intelligent Computing.
- 🌎 scikit-learn - The most popular Python library for Machine Learning.
- 🌎 Spark ML - Apache Spark's scalable Machine Learning library.
- vowpal_porpoise - ⭐ 164 🍴 30 - A lightweight Python wrapper for Vowpal Wabbit.
- xgboost - ⭐ 24378 🍴 8624 - A scalable, portable, and distributed gradient boosting library.
- MindsDB - ⭐ 17267 🍴 2206 - MindsDB is an open source AI layer for existing databases that allows you to effortlessly develop, train and deploy state-of-the-art machine learning models using standard queries.
Python programming on Microsoft Windows.
- 🌎 Python(x,y) - Scientific-applications-oriented Python Distribution based on Qt and Spyder.
- 🌎 pythonlibs - Unofficial Windows binaries for Python extension packages.
- PythonNet - ⭐ 3847 🍴 645 - Python Integration with the .NET Common Language Runtime (CLR).
- PyWin32 - ⭐ 4432 🍴 771 - Python Extensions for Windows.
- 🌎 WinPython - Portable development environment for Windows 7/8.
Useful libraries or tools that don't fit in the categories above.
- blinker - ⭐ 1538 🍴 177 - A fast Python in-process signal/event dispatching system.
- boltons - ⭐ 6232 🍴 345 - A set of pure-Python utilities.
- itsdangerous - ⭐ 2700 🍴 219 - Various helpers to pass trusted data to untrusted environments.
- magenta - ⭐ 18574 🍴 3753 - A tool to generate music and art using artificial intelligence.
- pluginbase - ⭐ 1063 🍴 145 - A simple but flexible plugin system for Python.
- 🌎 tryton - A general purpose business framework.
Libraries for working with human languages.
- General
- gensim - ⭐ 14499 🍴 4369 - Topic Modeling for Humans.
- langid.py - ⭐ 2109 🍴 304 - Stand-alone language identification system.
- 🌎 nltk - A leading platform for building Python programs to work with human language data.
- pattern - ⭐ 8519 🍴 1600 - A web mining module.
- polyglot - ⭐ 2188 🍴 332 - Natural language pipeline supporting hundreds of languages.
- pytext - ⭐ 6358 🍴 826 - A natural language modeling framework based on PyTorch.
- PyTorch-NLP - ⭐ 2186 🍴 260 - A toolkit enabling rapid deep learning NLP prototyping for research.
- 🌎 spacy - A library for industrial-strength natural language processing in Python and Cython.
- Stanza - ⭐ 6699 🍴 858 - The Stanford NLP Group's official Python library, supporting 60+ languages.
- Chinese
- funNLP - ⭐ 52697 🍴 12982 - A collection of tools and datasets for Chinese NLP.
- jieba - ⭐ 30917 🍴 6699 - The most popular Chinese text segmentation library.
- pkuseg-python - ⭐ 6197 🍴 972 - A toolkit for Chinese word segmentation in various domains.
- snownlp - ⭐ 6131 🍴 1360 - A library for processing Chinese text.
Tools and libraries for Virtual Networking and SDN (Software Defined Networking).
- mininet - ⭐ 4864 🍴 1717 - A popular network emulator and API written in Python.
- napalm - ⭐ 2081 🍴 545 - Cross-vendor API to manipulate network devices.
- pox - ⭐ 602 🍴 465 - A Python-based SDN control applications, such as OpenFlow SDN controllers.
Libraries for building user's activities.
- django-activity-stream - ⭐ 2222 🍴 490 - Generating generic activity streams from the actions on your site.
- Stream Framework - ⭐ 4694 🍴 569 - Building news feed and notification systems using Cassandra and Redis.
Libraries that implement Object-Relational Mapping or data mapping techniques.
- Relational Databases
- 🌎 Django Models - The Django ORM.
- 🌎 SQLAlchemy - The Python SQL Toolkit and Object Relational Mapper.
- awesome-sqlalchemy - ⭐ 2627 🍴 147
- dataset - ⭐ 4589 🍴 296 - Store Python dicts in a database - works with SQLite, MySQL, and PostgreSQL.
- orator - ⭐ 1405 🍴 168 - The Orator ORM provides a simple yet beautiful ActiveRecord implementation.
- orm - ⭐ 1737 🍴 99 - An async ORM.
- peewee - ⭐ 10193 🍴 1371 - A small, expressive ORM.
- pony - ⭐ 3270 🍴 237 - ORM that provides a generator-oriented interface to SQL.
- pydal - ⭐ 456 🍴 135 - A pure Python Database Abstraction Layer.
- NoSQL Databases
- hot-redis - ⭐ 284 🍴 31 - Rich Python data types for Redis.
- mongoengine - ⭐ 4025 🍴 1223 - A Python Object-Document-Mapper for working with MongoDB.
- PynamoDB - ⭐ 2216 🍴 422 - A Pythonic interface for Amazon DynamoDB.
- redisco - ⭐ 436 🍴 80 - A Python Library for Simple Models and Containers Persisted in Redis.
Libraries for package and dependency management.
- 🌎 pip - The package installer for Python.
- conda - ⭐ 5576 🍴 1392 - Cross-platform, Python-agnostic binary package manager.
- poetry - ⭐ 25742 🍴 2003 - Python dependency management and packaging made easy.
Local PyPI repository server and proxies.
- bandersnatch - ⭐ 374 🍴 142 - PyPI mirroring tool provided by Python Packaging Authority (PyPA).
- devpi - ⭐ 720 🍴 122 - PyPI server and packaging/testing/release tool.
- localshop - ⭐ 391 🍴 114 - Local PyPI server (custom packages and auto-mirroring of pypi).
- warehouse - ⭐ 3312 🍴 963 - Next generation Python Package Repository (PyPI).
Frameworks and tools for penetration testing.
- fsociety - ⭐ 8686 🍴 1847 - A Penetration testing framework.
- setoolkit - ⭐ 9097 🍴 2533 - A toolkit for social engineering.
- sqlmap - ⭐ 27518 🍴 5332 - Automatic SQL injection and database takeover tool.
Libraries that allow or deny users access to data or functionality.
- django-guardian - ⭐ 3400 🍴 554 - Implementation of per object permissions for Django 1.2+
- django-rules - ⭐ 1642 🍴 135 - A tiny but powerful app providing object-level permissions to Django, without requiring a database.
Libraries for starting and communicating with OS processes.
- delegator.py - ⭐ 1665 🍴 96 - Subprocesses for Humans 2.0.
- 🌎 sarge - Yet another wrapper for subprocess.
- sh - ⭐ 6656 🍴 499 - A full-fledged subprocess replacement for Python.
Libraries for building recommender systems.
- annoy - ⭐ 11607 🍴 1109 - Approximate Nearest Neighbors in C++/Python optimized for memory usage.
- fastFM - ⭐ 1039 🍴 206 - A library for Factorization Machines.
- implicit - ⭐ 3220 🍴 601 - A fast Python implementation of collaborative filtering for implicit datasets.
- libffm - ⭐ 1577 🍴 464 - A library for Field-aware Factorization Machine (FFM).
- lightfm - ⭐ 4383 🍴 673 - A Python implementation of a number of popular recommendation algorithms.
- spotlight - ⭐ 2881 🍴 419 - Deep recommender models using PyTorch.
- Surprise - ⭐ 5874 🍴 987 - A scikit for building and analyzing recommender systems.
- tensorrec - ⭐ 1236 🍴 224 - A Recommendation Engine Framework in TensorFlow.
Refactoring tools and libraries for Python
- 🌎 Bicycle Repair Man - Bicycle Repair Man, a refactoring tool for Python.
- 🌎 Bowler - Safe code refactoring for modern Python.
- Rope - ⭐ 1645 🍴 163 - Rope is a python refactoring library.
Libraries for building RESTful APIs.
- Django
- 🌎 django-rest-framework - A powerful and flexible toolkit to build web APIs.
- 🌎 django-tastypie - Creating delicious APIs for Django apps.
- Flask
- eve - ⭐ 6618 🍴 756 - REST API framework powered by Flask, MongoDB and good intentions.
- flask-api - ⭐ 1383 🍴 185 - Browsable Web APIs for Flask.
- flask-restful - ⭐ 6625 🍴 1028 - Quickly building REST APIs for Flask.
- Pyramid
- cornice - ⭐ 374 🍴 153 - A RESTful framework for Pyramid.
- Framework agnostic
- apistar - ⭐ 5601 🍴 427 - A smart Web API framework, designed for Python 3.
- falcon - ⭐ 9190 🍴 917 - A high-performance framework for building cloud APIs and web app backends.
- fastapi - ⭐ 60384 🍴 5059 - A modern, fast, web framework for building APIs with Python 3.6+ based on standard Python type hints.
- hug - ⭐ 6729 🍴 388 - A Python 3 framework for cleanly exposing APIs.
- sandman2 - ⭐ 1953 🍴 216 - Automated REST APIs for existing database-driven systems.
- sanic - ⭐ 17185 🍴 1523 - A Python 3.6+ web server and web framework that's written to go fast.
- 🌎 vibora - Fast, efficient and asynchronous Web framework inspired by Flask.
Libraries for robotics.
- PythonRobotics - ⭐ 19218 🍴 5937 - This is a compilation of various robotics algorithms with visualizations.
- 🌎 rospy - This is a library for ROS (Robot Operating System).
RPC-compatible servers.
- RPyC (Remote Python Call) - ⭐ 1414 🍴 237 - A transparent and symmetric RPC library for Python
- zeroRPC - ⭐ 3086 🍴 388 - zerorpc is a flexible RPC implementation based on ZeroMQ and MessagePack.
Libraries for scientific computing. Also see Python-for-Scientists.
- 🌎 astropy - A community Python library for Astronomy.
- bcbio-nextgen - ⭐ 940 🍴 357 - Providing best-practice pipelines for fully automated high throughput sequencing analysis.
- bccb - ⭐ 572 🍴 239 - Collection of useful code related to biological analysis.
- 🌎 Biopython - Biopython is a set of freely available tools for biological computation.
- 🌎 cclib - A library for parsing and interpreting the results of computational chemistry packages.
- 🌎 Colour - Implementing a comprehensive number of colour theory transformations and algorithms.
- Karate Club - ⭐ 1931 🍴 231 - Unsupervised machine learning toolbox for graph structured data.
- 🌎 NetworkX - A high-productivity software for complex networks.
- 🌎 NIPY - A collection of neuroimaging toolkits.
- 🌎 NumPy - A fundamental package for scientific computing with Python.
- ObsPy - ⭐ 1046 🍴 520 - A Python toolbox for seismology.
- 🌎 Open Babel - A chemical toolbox designed to speak the many languages of chemical data.
- 🌎 PyDy - Short for Python Dynamics, used to assist with workflow in the modeling of dynamic motion.
- PyMC - ⭐ 7663 🍴 1797 - Markov Chain Monte Carlo sampling toolkit.
- 🌎 QuTiP - Quantum Toolbox in Python.
- 🌎 RDKit - Cheminformatics and Machine Learning Software.
- 🌎 SciPy - A Python-based ecosystem of open-source software for mathematics, science, and engineering.
- 🌎 SimPy - A process-based discrete-event simulation framework.
- statsmodels - ⭐ 8679 🍴 2735 - Statistical modeling and econometrics in Python.
- SymPy - ⭐ 11056 🍴 3991 - A Python library for symbolic mathematics.
- Zipline - ⭐ 16305 🍴 4606 - A Pythonic algorithmic trading library.
Libraries and software for indexing and performing search queries on data.
- django-haystack - ⭐ 3441 🍴 1314 - Modular search for Django.
- elasticsearch-dsl-py - ⭐ 3678 🍴 794 - The official high-level Python client for Elasticsearch.
- 🌎 elasticsearch-py - The official low-level Python client for Elasticsearch.
- pysolr - ⭐ 641 🍴 331 - A lightweight Python wrapper for Apache Solr.
- 🌎 whoosh - A fast, pure Python search engine library.
Libraries for serializing complex data types
- marshmallow - ⭐ 6602 🍴 628 - A lightweight library for converting complex objects to and from simple Python datatypes.
- pysimdjson - ⭐ 592 🍴 49 - A Python bindings for simdjson.
- python-rapidjson - ⭐ 481 🍴 43 - A Python wrapper around RapidJSON.
- ultrajson - ⭐ 4103 🍴 368 - A fast JSON decoder and encoder written in C with Python bindings.
Frameworks for developing serverless Python code.
- python-lambda - ⭐ 1442 🍴 232 - A toolkit for developing and deploying Python code in AWS Lambda.
- Zappa - ⭐ 11901 🍴 1253 - A tool for deploying WSGI applications on AWS Lambda and API Gateway.
Shells based on Python.
- xonsh - ⭐ 7119 🍴 612 - A Python-powered, cross-platform, Unix-gazing shell language and command prompt.
Libraries for parsing and manipulating specific text formats.
- General
- tablib - ⭐ 4257 🍴 578 - A module for Tabular Datasets in XLS, CSV, JSON, YAML.
- Office
- docxtpl - ⭐ 1610 🍴 346 - Editing a docx document by jinja2 template
- 🌎 openpyxl - A library for reading and writing Excel 2010 xlsx/xlsm/xltx/xltm files.
- pyexcel - ⭐ 1129 🍴 163 - Providing one API for reading, manipulating and writing csv, ods, xls, xlsx and xlsm files.
- python-docx - ⭐ 3688 🍴 979 - Reads, queries and modifies Microsoft Word 2007/2008 docx files.
- python-pptx - ⭐ 1835 🍴 434 - Python library for creating and updating PowerPoint (.pptx) files.
- unoconv - ⭐ 2428 🍴 404 - Convert between any document format supported by LibreOffice/OpenOffice.
- XlsxWriter - ⭐ 3286 🍴 612 - A Python module for creating Excel .xlsx files.
- xlwings - ⭐ 2638 🍴 472 - A BSD-licensed library that makes it easy to call Python from Excel and vice versa.
- xlwt / xlrd - ⭐ 1025 🍴 295 - Writing and reading data and formatting information from Excel files.
- PDF
- PDFMiner - ⭐ 5051 🍴 1135 - A tool for extracting information from PDF documents.
- PyPDF2 - ⭐ 5911 🍴 1236 - A library capable of splitting, merging and transforming PDF pages.
- 🌎 ReportLab - Allowing Rapid creation of rich PDF documents.
- Markdown
- Mistune - ⭐ 2296 🍴 237 - Fastest and full featured pure Python parsers of Markdown.
- Python-Markdown - ⭐ 3284 🍴 838 - A Python implementation of John Gruber’s Markdown.
- YAML
- 🌎 PyYAML - YAML implementations for Python.
- CSV
- csvkit - ⭐ 5513 🍴 595 - Utilities for converting to and working with CSV.
- Archive
- unp - ⭐ 407 🍴 57 - A command line tool that can unpack archives easily.
Static site generator is a software that takes some text + templates as input and produces HTML files on the output.
- lektor - ⭐ 3682 🍴 314 - An easy to use static CMS and blog engine.
- mkdocs - ⭐ 16735 🍴 2276 - Markdown friendly documentation generator.
- makesite - ⭐ 1725 🍴 285 - Simple, lightweight, and magic-free static site/blog generator (< 130 lines).
- nikola - ⭐ 2460 🍴 444 - A static website and blog generator.
- pelican - ⭐ 11660 🍴 1820 - Static site generator that supports Markdown and reST syntax.
Libraries for tagging items.
- django-taggit - ⭐ 3063 🍴 615 - Simple tagging for Django.
Libraries for working with task queues.
- 🌎 celery - An asynchronous task queue/job queue based on distributed message passing.
- daramatiq - ⭐ 3651 🍴 258 - A fast and reliable background task processing library for Python 3.
- huey - ⭐ 4540 🍴 365 - Little multi-threaded task queue.
- mrq - ⭐ 874 🍴 121 - A distributed worker task queue in Python using Redis & gevent.
- rq - ⭐ 9004 🍴 1360 - Simple job queues for Python.
Libraries and tools for templating and lexing.
- 🌎 Genshi - Python templating toolkit for generation of web-aware output.
- Jinja2 - ⭐ 9369 🍴 1569 - A modern and designer friendly templating language.
- 🌎 Mako - Hyperfast and lightweight templating for the Python platform.
Libraries for testing codebases and generating test data.
- Testing Frameworks
- hypothesis - ⭐ 6797 🍴 565 - Hypothesis is an advanced Quickcheck style property based testing library.
- nose2 - ⭐ 757 🍴 137 - The successor to
nose
, based on `unittest2. - 🌎 pytest - A mature full-featured Python testing tool.
- Robot Framework - ⭐ 8197 🍴 2148 - A generic test automation framework.
- 🌎 unittest - (Python standard library) Unit testing framework.
- Test Runners
- GUI / Web Testing
- locust - ⭐ 21719 🍴 2720 - Scalable user load testing tool written in Python.
- PyAutoGUI - ⭐ 8333 🍴 1086 - PyAutoGUI is a cross-platform GUI automation Python module for human beings.
- Schemathesis - ⭐ 1785 🍴 131 - A tool for automatic property-based testing of web applications built with Open API / Swagger specifications.
- 🌎 Selenium - Python bindings for Selenium WebDriver.
- sixpack - ⭐ 1751 🍴 189 - A language-agnostic A/B Testing framework.
- splinter - ⭐ 2642 🍴 509 - Open source tool for testing web applications.
- Mock
- 🌎 doublex - Powerful test doubles framework for Python.
- freezegun - ⭐ 3730 🍴 254 - Travel through time by mocking the datetime module.
- httmock - ⭐ 457 🍴 55 - A mocking library for requests for Python 2.6+ and 3.2+.
- httpretty - ⭐ 2056 🍴 268 - HTTP request mock tool for Python.
- 🌎 mock - (Python standard library) A mocking and patching library.
- mocket - ⭐ 264 🍴 41 - A socket mock framework with gevent/asyncio/SSL support.
- responses - ⭐ 3909 🍴 331 - A utility library for mocking out the requests Python library.
- VCR.py - ⭐ 2438 🍴 340 - Record and replay HTTP interactions on your tests.
- Object Factories
- factory_boy - ⭐ 3149 🍴 378 - A test fixtures replacement for Python.
- mixer - ⭐ 907 🍴 95 - Another fixtures replacement. Supported Django, Flask, SQLAlchemy, Peewee and etc.
- model_mommy - ⭐ 914 🍴 147 - Creating random fixtures for testing in Django.
- Code Coverage
- 🌎 coverage - Code coverage measurement.
- Fake Data
Libraries for parsing and manipulating plain texts.
- General
- chardet - ⭐ 1933 🍴 250 - Python 2/3 compatible character encoding detector.
- 🌎 difflib - (Python standard library) Helpers for computing deltas.
- ftfy - ⭐ 3519 🍴 117 - Makes Unicode text less broken and more consistent automagically.
- fuzzywuzzy - ⭐ 8914 🍴 898 - Fuzzy String Matching.
- Levenshtein - ⭐ 1230 🍴 156 - Fast computation of Levenshtein distance and string similarity.
- pangu.py - ⭐ 207 🍴 24 - Paranoid text spacing.
- pyfiglet - ⭐ 1175 🍴 111 - An implementation of figlet written in Python.
- pypinyin - ⭐ 4390 🍴 592 - Convert Chinese hanzi (漢字) to pinyin (拼音).
- textdistance - ⭐ 3140 🍴 244 - Compute distance between sequences with 30+ algorithms.
- 🌎 unidecode - ASCII transliterations of Unicode text.
- Slugify
- awesome-slugify - ⭐ 476 🍴 46 - A Python slugify library that can preserve unicode.
- python-slugify - ⭐ 1354 🍴 101 - A Python slugify library that translates unicode to ASCII.
- unicode-slugify - ⭐ 318 🍴 52 - A slugifier that generates unicode slugs with Django as a dependency.
- Unique identifiers
- Parser
- ply - ⭐ 2526 🍴 442 - Implementation of lex and yacc parsing tools for Python.
- 🌎 pygments - A generic syntax highlighter.
- pyparsing - ⭐ 1902 🍴 260 - A general purpose framework for generating parsers.
- python-nameparser - ⭐ 596 🍴 100 - Parsing human names into their individual components.
- python-phonenumbers - ⭐ 3258 🍴 412 - Parsing, formatting, storing and validating international phone numbers.
- python-user-agents - ⭐ 1361 🍴 201 - Browser user agent parser.
- sqlparse - ⭐ 3320 🍴 652 - A non-validating SQL parser.
Libraries for accessing third party services APIs. Also see List of Python API Wrappers and Libraries.
- 🌎 apache-libcloud - One Python library for all clouds.
- boto3 - ⭐ 8197 🍴 1777 - Python interface to Amazon Web Services.
- django-wordpress - ⭐ 338 🍴 84 - WordPress models and views for Django.
- facebook-sdk - ⭐ 2689 🍴 990 - Facebook Platform Python SDK.
- google-api-python-client - ⭐ 6728 🍴 2364 - Google APIs Client Library for Python.
- gspread - ⭐ 6491 🍴 919 - Google Spreadsheets Python API.
- twython - ⭐ 1854 🍴 405 - A Python wrapper for the Twitter API.
Libraries for parsing URLs.
- furl - ⭐ 2480 🍴 151 - A small Python library that makes parsing and manipulating URLs easy.
- purl - ⭐ 291 🍴 38 - A simple, immutable URL class with a clean API for interrogation and manipulation.
- pyshorteners - ⭐ 364 🍴 65 - A pure Python URL shortening lib.
- webargs - ⭐ 1336 🍴 157 - A friendly library for parsing HTTP request arguments with built-in support for popular web frameworks.
Libraries for manipulating video and GIFs.
- 🌎 moviepy - A module for script-based movie editing with many formats, including animated GIFs.
- scikit-video - ⭐ 124 🍴 22 - Video processing routines for SciPy.
- vidgear - ⭐ 2848 🍴 224 - Most Powerful multi-threaded Video Processing framework.
Tools for managing, compressing and minifying website assets.
- django-compressor - ⭐ 2691 🍴 586 - Compresses linked and inline JavaScript or CSS into a single cached file.
- django-pipeline - ⭐ 1469 🍴 377 - An asset packaging library for Django.
- django-storages - ⭐ 2442 🍴 828 - A collection of custom storage back ends for Django.
- 🌎 fanstatic - Packages, optimizes, and serves static file dependencies as Python packages.
- 🌎 fileconveyor - A daemon to detect and sync files to CDNs, S3 and FTP.
- flask-assets - ⭐ 438 🍴 98 - Helps you integrate webassets into your Flask app.
- webassets - ⭐ 917 🍴 262 - Bundles, optimizes, and manages unique cache-busting URLs for static resources.
Libraries for extracting web contents.
- html2text - ⭐ 1433 🍴 242 - Convert HTML to Markdown-formatted text.
- lassie - ⭐ 586 🍴 49 - Web Content Retrieval for Humans.
- micawber - ⭐ 603 🍴 91 - A small library for extracting rich content from URLs.
- newspaper - ⭐ 12934 🍴 2051 - News extraction, article extraction and content curation in Python.
- python-readability - ⭐ 2308 🍴 345 - Fast Python port of arc90's readability tool.
- requests-html - ⭐ 13230 🍴 965 - Pythonic HTML Parsing for Humans.
- sumy - ⭐ 3203 🍴 512 - A module for automatic summarization of text documents and HTML pages.
- textract - ⭐ 3574 🍴 535 - Extract text from any document, Word, PowerPoint, PDFs, etc.
- toapi - ⭐ 3394 🍴 247 - Every web site provides APIs.
Libraries to automate web scraping.
- cola - ⭐ 1473 🍴 546 - A distributed crawling framework.
- 🌎 feedparser - Universal feed parser.
- grab - ⭐ 2294 🍴 278 - Site scraping framework.
- MechanicalSoup - ⭐ 4406 🍴 394 - A Python library for automating interaction with websites.
- portia - ⭐ 8934 🍴 1415 - Visual scraping for Scrapy.
- pyspider - ⭐ 15952 🍴 3683 - A powerful spider system.
- robobrowser - ⭐ 3680 🍴 343 - A simple, Pythonic library for browsing the web without a standalone web browser.
- 🌎 scrapy - A fast high-level screen scraping and web crawling framework.
Traditional full stack web frameworks. Also see RESTful API.
- Synchronous
- 🌎 Django - The most popular web framework in Python.
- awesome-django - ⭐ 1239 🍴 221
- awesome-django - ⭐ 7218 🍴 1066
- 🌎 Flask - A microframework for Python.
- awesome-flask - ⭐ 11468 🍴 1571
- 🌎 Pyramid - A small, fast, down-to-earth, open source Python web framework.
- awesome-pyramid - ⭐ 540 🍴 59
- Masonite - ⭐ 2045 🍴 129 - The modern and developer centric Python web framework.
- 🌎 Django - The most popular web framework in Python.
- Asynchronous
- 🌎 Tornado - A web framework and asynchronous networking library.
Libraries for working with WebSocket.
- autobahn-python - ⭐ 2429 🍴 770 - WebSocket & WAMP for Python on Twisted and asyncio.
- channels - ⭐ 5657 🍴 783 - Developer-friendly asynchrony for Django.
- websockets - ⭐ 4620 🍴 493 - A library for building WebSocket servers and clients with a focus on correctness and simplicity.
WSGI-compatible web servers.
- bjoern - ⭐ 2923 🍴 190 - Asynchronous, very fast and written in C.
- gunicorn - ⭐ 9027 🍴 1665 - Pre-forked, partly written in C.
- 🌎 uWSGI - A project aims at developing a full stack for building hosting services, written in C.
- waitress - ⭐ 1273 🍴 159 - Multi-threaded, powers Pyramid.
- werkzeug - ⭐ 6400 🍴 1714 - A WSGI utility library for Python that powers Flask and can easily be embedded into your own projects.
Where to discover learning resources or new Python libraries.
- Tutorials
- Libraries
- 🌎 Awesome Python @LibHunt
- 🌎 Explore Python - Discover & find a curated list of popular & new libraries, top authors, trending project kits, discussions, tutorials & learning resources on kandi.
- Others
- 🌎 Python ZEEF
- 🌎 Pythonic News
- What the f*ck Python! - ⭐ 32855 🍴 2575
- 🌎 Django Chat
- 🌎 Podcast.__init__
- 🌎 Python Bytes
- 🌎 Running in Production
- 🌎 Talk Python To Me
- 🌎 Test and Code
- 🌎 The Real Python Podcast
Your contributions are always welcome!
If you find out any repo has been outdate or its link has not valid anymore, please open a pull request. I will merge it soon.
If you want to add a new repo, please go to awesome-python and create a pull request first.