Python for .NET is a package that gives Python programmers nearly seamless integration with the .NET Common Language Runtime (CLR) and provides a powerful application scripting tool for .NET developers.
C# Python C Other
Clone or download
Permalink
Failed to load latest commit information.
.github Fix paths in PULL_REQUEST_TEMPLATE.md Jan 22, 2017
ci Added CoreCLR 2.0 build target. Compile issues fixed. (#519) Sep 21, 2017
conda.recipe Msbuild15 patch (#435) Mar 23, 2017
demo WPF DynamicGrid python and XAML layout files (#280) Mar 23, 2017
src Adds method name to "no method matches" error (#653) Jul 16, 2018
tools Build system improvements pack - addressing comments to PR and some i… Nov 7, 2017
.bumpversion.cfg Bump version: 2.3.0.→ 2.4.0.dev0 Mar 11, 2017
.editorconfig improve tests.pyproj for intellisense and running tests (#395) Feb 24, 2017
.gitignore Add Coverity badge Feb 17, 2017
.mention-bot Update .mention-bot Mar 28, 2017
.travis.yml Update .travis.yml Jun 12, 2018
AUTHORS.md Adds method name to "no method matches" error (#653) Jul 16, 2018
CHANGELOG.md Adds method name to "no method matches" error (#653) Jul 16, 2018
CONTRIBUTING.md Clean-up README/CONTRIBUTING Jan 14, 2017
LICENSE Update LICENSE year & include in recipe Feb 22, 2017
NuGet.config CoreCLR msbuild (xplat) support. Initial compilable version. (#518) Sep 21, 2017
README.md Update README.md Feb 6, 2018
appveyor.yml Update appveyor.yml Jun 12, 2018
pythonnet.15.sln Added CoreCLR 2.0 build target. Compile issues fixed. (#519) Sep 21, 2017
pythonnet.sln Revert "fix for "handle is not inialized" crash on `clr.GetClrType(Sy… Jan 28, 2018
requirements.txt Update requirements.txt May 28, 2018
setup.cfg Add timing to detect slow tests on pytest Mar 5, 2017
setup.py Fixed problem with --xplat build when mono does not installed. Nov 15, 2017
tox.ini Remove check-manifest Feb 14, 2017

README.md

pythonnet - Python for .NET

Join the chat at https://gitter.im/pythonnet/pythonnet

appveyor shield travis shield codecov shield coverity shield

license shield pypi package version python supported shield stackexchange shield slack

Python for .NET is a package that gives Python programmers nearly seamless integration with the .NET Common Language Runtime (CLR) and provides a powerful application scripting tool for .NET developers. It allows Python code to interact with the CLR, and may also be used to embed Python into a .NET application.

Calling .NET code from Python

Python for .NET allows CLR namespaces to be treated essentially as Python packages.

import clr
from System import String
from System.Collections import *

To load an assembly, use the AddReference function in the clr module:

import clr
clr.AddReference("System.Windows.Forms")
from System.Windows.Forms import Form

Embedding Python in .NET

  • All calls to python should be inside a using (Py.GIL()) {/* Your code here */} block.
  • Import python modules using dynamic mod = Py.Import("mod"), then you can call functions as normal, eg mod.func(args).
  • Use mod.func(args, Py.kw("keywordargname", keywordargvalue)) or mod.func(args, keywordargname: keywordargvalue) to apply keyword arguments.
  • All python objects should be declared as dynamic type.
  • Mathematical operations involving python and literal/managed types must have the python object first, eg. np.pi * 2 works, 2 * np.pi doesn't.

Example

static void Main(string[] args)
{
    using (Py.GIL())
    {
        dynamic np = Py.Import("numpy");
        Console.WriteLine(np.cos(np.pi * 2));

        dynamic sin = np.sin;
        Console.WriteLine(sin(5));

        double c = np.cos(5) + sin(5);
        Console.WriteLine(c);

        dynamic a = np.array(new List<float> { 1, 2, 3 });
        Console.WriteLine(a.dtype);

        dynamic b = np.array(new List<float> { 6, 5, 4 }, dtype: np.int32);
        Console.WriteLine(b.dtype);

        Console.WriteLine(a * b);
        Console.ReadKey();
    }
}

Output:

1.0
-0.958924274663
-0.6752620892
float64
int32
[  6.  10.  12.]

Information on installation, FAQ, troubleshooting, debugging, and projects using pythonnet can be found in the Wiki:

https://github.com/pythonnet/pythonnet/wiki