To get started with CSnakes, you need to:
- Install Python
- Put your Python files into a C# Project
- Use type annotations for the functions you want to call from C#
- Install the
CSnakes.Runtime
package into the project - Mark them for source generation
- Install the
CSnakes.Runtime
nuget package in the C# Project you want to execute the Python code from - Setup a Virtual Environment (Optional)
- Instantiate a Python environment in C# and run the Python function
Because CSnakes embeds Python in your .NET project, you need to have Python installed on your machine. CSnakes supports Python 3.9-3.13.
Embedding Python is a bit different to running python
on the command line, because it requires 3 paths, instead of just one (python
):
- The path to the Python library, sometimes called
python3.dll
orlibpython3.so
. - The path to the Python standard library, which is a directory containing the Python standard library.
- The path to your Python code
And, optionally, a path to a virtual environment if you have one.
To make this easier, we've bundled Python Locators as extension methods to the environment builder with common installation paths for Python.
To setup a C# project for CSnakes, you need to:
- Create a new C# project or open an existing one.
- Add your Python files to the project.
- Mark the Python files as "Additional Files" in the project file.
- Install the
CSnakes.Runtime
NuGet package. - Create a
PythonEnvironment
in C# and create an instance of the Python module. - Call any Python code.
CSnakes is bundled into a single nuget package, CSnakes.Runtime
. This package includes the source generator and runtime libraries.
Source Generation is recommended for the best experience, but you can also use the runtime library directly if you prefer, see Calling Python without the Source Generator.
CSnakes uses the Python type annotations to generate C# code. You need to add Python files to your project and add type annotations to the functions you want to call from C#.
For example, if you were to create a Python file called demo.py
to your project with the following content:
def hello_world(name: str) -> str:
return f"Hello, {name}!"
See the reference supported types for a list of Python types and their C#.NET equivalents.
For CSnakes to run the source generator over Python files, you need to mark the Python file as an "Additional File" in the CSProj file XML:
<ItemGroup>
<AdditionalFiles Include="demo.py">
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
</AdditionalFiles>
</ItemGroup>
Or, in Visual Studio change the properties of the file and set Build Action to Csharp analyzer additional file.
After you've added the Python files to the project, installed the NuGet packages, and marked the Python files for generation, you can build the project using dotnet build
.
Python environments created by CSnakes are designed to be process-level singletons. This means that you can create a Python environment once and use it throughout the lifetime of the process.
CSnakes comes with a host builder for the Microsoft.Extensions.Hosting
library to make it easier to create a Python environment in your C# code.
CSnakes also needs to know where to find Python using one or many Python Locators.
The simplest option is the FromRedistributable
method, which will download a Python 3.12 redistributable and store it locally. This is compatible with Windows, macOS, and Linux.
Here's an example of how you can create a Python environment in C#:
using CSnakes.Runtime;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using System;
using System.Collections.Generic;
using System.IO;
using System.Text.Json;
var builder = Host.CreateDefaultBuilder(args)
.ConfigureServices(services =>
{
var home = Path.Join(Environment.CurrentDirectory, "."); /* Path to your Python modules */
services
.WithPython()
.WithHome(home)
.FromRedistributable(); // Download Python 3.12 and store it locally
});
var app = builder.Build();
var env = app.Services.GetRequiredService<IPythonEnvironment>();
Check out the sample project in the samples for code examples of a .NET console application and web application.
Since most Python projects require external dependencies outside of the Python standard library, CSnakes supports execution within a Python virtual environment and Conda environments.
Use the .WithVirtualEnvironment
method to specify the path to the virtual environment.
You can also optionally use the .WithPipInstaller()
method to install packages listed in a requirements.txt
file in the virtual environment. If you don't use this method, you need to install the packages manually before running the application.
...
services
.WithPython()
.WithVirtualEnvironment(Path.Join(home, ".venv"))
// Python locators
.WithPipInstaller(); // Optional - installs packages listed in requirements.txt on startup
See Environment and Package Management for more information on managing Python environments and dependencies.
Once you have a Python environment, you can call any Python function from C# using the IPythonEnvironment
interface.
Here's an example of how you can call the hello_world
function from the demo.py
file:
var env = app.Services.GetRequiredService<IPythonEnvironment>();
var module = env.Demo();
var result = module.HelloWorld("Alice");
Console.WriteLine(result); // Hello, Alice!
Check out the reference for more information on supported types and features.