Extension et intégration de l’interpréteur Python¶
Ce document décrit comment écrire des modules en C ou C++ pour étendre l’interpréteur Python à de nouveaux modules. En plus de définir de nouvelles fonctions, ces modules peuvent définir de nouveaux types d’objets ainsi que leur méthodes. Ce document explique aussi comment intégrer l’interpréteur Python dans une autre application, pour être utilisé comme langage d’extension. Enfin, ce document montre comment compiler et lier les modules d’extension pour qu’ils puissent être chargés dynamiquement (à l’exécution) dans l’interpréteur, si le système d’exploitation sous-jacent supporte cette fonctionnalité.
Ce document présuppose que vous avez des connaissances de base sur Python. Pour une introduction informelle du langage, voyez Le tutoriel Python. La référence du langage Python donne une définition plus formelle du langage. La bibliothèque standard documente les objets types, fonctions et modules existants (tous intégrés et écrits en Python) qui donnent au langage sa large gamme d’applications.
Pour une description dans sa totalité de l’API Python/C, voir Manuel de référence de l’API Python/C.
Les outils tiers recommandés¶
This guide only covers the basic tools for creating extensions provided
as part of this version of CPython. Third party tools like Cython,
cffi
, SWIG and Numba offer both simpler and more sophisticated
approaches to creating C and C++ extensions for Python.
Voir aussi
- Guide d’utilisation de l’empaquetage Python : Extensions binaires
- Le guide d’utilisation de l’empaquetage Python ne couvre pas uniquement quelques outils disponibles qui simplifient la création d’extensions binaires, mais aborde aussi les différentes raisons pour lesquelles créer un module d’extension peut être souhaitable d’entrée.
Création d’extensions sans outils tiers¶
Cette section du guide couvre la création d’extensions C et C++ sans l’utilisation d’outils tiers. Cette section est destinée aux créateurs de ces outils, plus que d’être une méthode recommandée pour créer votre propre extension C.
- 1. Étendre Python en C ou C++
- 1.1. Un exemple simple
- 1.2. Intermezzo: Les erreurs et exceptions
- 1.3. Retour vers l’exemple
- 1.4. La fonction d’initialisation et le tableau des méthodes du module
- 1.5. Compilation and Linkage
- 1.6. Calling Python Functions from C
- 1.7. Extracting Parameters in Extension Functions
- 1.8. Keyword Parameters for Extension Functions
- 1.9. Building Arbitrary Values
- 1.10. Reference Counts
- 1.11. Writing Extensions in C++
- 1.12. Providing a C API for an Extension Module
- 2. Defining New Types
- 3. Construire des extensions C et C++
- 4. Construire des extensions C et C++ sur Windows
Intégrer l’interpréteur CPython dans une plus grande application¶
Parfois, plutôt que de créer une extension qui s’exécute dans l’interpréteur Python comme application principale, il est préférable d’intégrer l’interpréteur Python dans une application plus large. Cette section donne quelques informations nécessaires au succès de cette opération.