Kommentar
Åtkomst till den här sidan kräver auktorisering. Du kan prova att logga in eller ändra kataloger.
Åtkomst till den här sidan kräver auktorisering. Du kan prova att ändra kataloger.
Warning
Prompt Flow-funktionsutvecklingen avslutades den 20 april 2026. Funktionen dras tillbaka helt den 20 april 2027. På avslutsdatumet går Prompt Flow in i skrivskyddat läge. Dina befintliga flöden fortsätter att fungera fram till det datumet.
Recommended action: Migrera dina Prompt Flow-arbetsbelastningar till Microsoft Agent Framework före 20 april 2027.
Med verktyget Python kan du skapa anpassade kodfragment som fristående körbara noder i promptflödet. Du kan enkelt skapa Python verktyg, redigera kod och verifiera resultat.
Inputs
| Name | Type | Description | Required |
|---|---|---|---|
| Code | string | Python kodfragment | Yes |
| Inputs | - | Lista över verktygsfunktionsparametrar och deras tilldelningar | - |
Types
| Type | Python example | Description |
|---|---|---|
| int | param: int | Integer type |
| bool | param: bool | Boolean type |
| string | param: str | String type |
| double | param: float | Double type |
| list | param: list eller param: List[T] | List type |
| object | param: dict eller param: Dict[K, V] | Object type |
| Connection | param: CustomConnection | Anslutningstypen hanteras särskilt |
Parametrar med typanteckningen Connection behandlas som anslutningsindata, vilket innebär:
- Tillägg för promptflöde visar en väljare för att välja anslutningen.
- Under körningen försöker promptflödet hitta anslutningen med samma namn från parametervärdet som skickades in.
Note
Typanteckningen Union[...] stöds endast för anslutningstypen, till exempel param: Union[CustomConnection, OpenAIConnection].
Outputs
Utdata är returvärdet för Python verktygsfunktionen.
Skriva med verktyget Python
Använd följande riktlinjer när du skriver med verktyget Python.
Guidelines
Python verktygskod bör bestå av fullständig Python kod, inklusive alla nödvändiga modulimporter.
Python verktygskod måste innehålla en funktion som är dekorerad med
@tool(verktygsfunktion), som fungerar som startpunkt för körning. Använd dekoratören@toolbara en gång i kodfragmentet.Följande exempel definierar verktyget Python
my_python_tool, som är dekorerat med@tool.Python verktygsfunktionsparametrar måste tilldelas i avsnittet
Inputs.Följande exempel definierar indata
messageoch tilldelar denworld.En Python verktygsfunktion måste ha ett returvärde.
Följande exempel returnerar en sammanfogad sträng.
Code
Följande kodfragment visar den grundläggande strukturen för en verktygsfunktion. Prompt flow läser funktionen och extraherar indata från funktionsparametrar och skriver anteckningar.
from promptflow import tool
from promptflow.connections import CustomConnection
# The inputs section will change based on the arguments of the tool function, after you save the code
# Adding type to arguments and return value will help the system show the types properly
# Please update the function name/signature per need
@tool
def my_python_tool(message: str, my_conn: CustomConnection) -> str:
my_conn_dict = dict(my_conn)
# Do some function call with my_conn_dict...
return 'hello ' + message
Inputs
| Name | Type | Exempelvärde i flödes-YAML | Värde som skickas till funktionen |
|---|---|---|---|
| message | string | world |
world |
| my_conn | CustomConnection |
my_conn |
CustomConnection Objekt |
Prompt flow försöker hitta anslutningen med namnet my_conn under körningen.
Outputs
"hello world"
Anropa en resonemangsmodell från verktyget Python
Om du behöver anropa resonemangsmodeller som LLM-noden inte stöder kan du använda verktyget Python för att anropa modellerna direkt. I följande exempel visas hur du anropar en resonemangsmodell från verktyget Python.
from promptflow import tool
from promptflow.connections import AzureOpenAIConnection
from openai import AzureOpenAI
@tool
def my_python_tool(
OpenAIConnection: AzureOpenAIConnection,
scope_reply: str
):
model_name = "o3-mini"
deployment = "o3-mini"
print(OpenAIConnection['api_base'])
endpoint = OpenAIConnection['api_base'] #"https://<your endpoint>.openai.azure.com/"
model_name = "o3-mini" #your model name
deployment = "o3-mini" #your deployment name
subscription_key = OpenAIConnection['api_key']
api_version = "2024-12-01-preview" #Supply an API version that supports reasoning models.
client = AzureOpenAI(
api_version=api_version,
azure_endpoint=endpoint,
api_key=subscription_key,
)
response = client.chat.completions.create(
messages=[
{
"role": "system",
"content": "You are a helpful assistant.",
},
{
"role": "user",
"content": "I am going to Paris, what should I see?",
}
],
max_completion_tokens=100000,
model=deployment
)
return response.choices[0].message.content
Anpassad anslutning i verktyget Python
Om du utvecklar ett Python verktyg som kräver att externa tjänster anropas med autentisering använder du den anpassade anslutningen i promptflödet. Du kan använda den för att lagra åtkomstnyckeln på ett säkert sätt och sedan hämta den i din Python kod.
Skapa en anpassad anslutning
Skapa en anpassad anslutning som lagrar alla dina API-nycklar för stora språkmodeller eller andra nödvändiga autentiseringsuppgifter.
Gå till kommandotolkens flöde på arbetsytan och välj sedan fliken Anslutningar .
Välj Skapa>anpassad.
I den högra rutan kan du definiera ditt anslutningsnamn. Du kan lägga till flera nyckel/värde-par för att lagra dina autentiseringsuppgifter och nycklar genom att välja Lägg till nyckel/värde-par.
Note
Om du vill ange ett nyckel/värde-par som hemlighet markerar du kryssrutan är hemlig . Det här alternativet krypterar och lagrar ditt nyckelvärde. Kontrollera att minst ett nyckel/värde-par har angetts som hemlighet. Annars skapas inte anslutningen.
Använda en anpassad anslutning i Python
Så här använder du en anpassad anslutning i din Python-kod:
I kodavsnittet i noden Python importerar du det anpassade anslutningsbiblioteket
from promptflow.connections import CustomConnection. Definiera en indataparameter av typenCustomConnectioni verktygsfunktionen.Parsa indata till indataavsnittet och välj sedan din anpassade målanslutning i listrutan Värde .
For example:
from promptflow import tool
from promptflow.connections import CustomConnection
@tool
def my_python_tool(message: str, myconn: CustomConnection) -> str:
# Get authentication key-values from the custom connection
connection_key1_value = myconn.key1
connection_key2_value = myconn.key2