Del via


Stoff Oversikt over programmeringsmodell for brukerdatafunksjoner

Fabric User datafunksjonsprogrammeringsmodellen definerer mønstre og konsepter for å lage funksjoner i Fabric.

SDK-en fabric-user-data-functions implementerer denne programmeringsmodellen og gir nødvendig funksjonalitet for å lage og publisere kjørbare funksjoner. SDK lar deg også sømløst integrere med andre elementer i Fabric-økosystemet, for eksempel Fabric-datakilder. Dette biblioteket er offentlig tilgjengelig i PyPI- og er forhåndsinstallert i elementene for brukerdatafunksjoner.

Denne artikkelen forklarer hvordan man bruker SDK-en til å bygge funksjoner som kan kalles fra Fabric-portalen, andre Fabric-elementer eller eksterne applikasjoner som bruker REST API. Du lærer programmeringsmodellen og nøkkelkonsepter med praktiske eksempler.

Tips

For fullstendige detaljer om alle klasser, metoder og parametere, se SDK-referansedokumentasjonen.

Å komme i gang med SDK-en

Denne delen introduserer kjernekomponentene i User Data Functions SDK og forklarer hvordan du strukturerer funksjonene dine. Du lærer om nødvendige importer, dekoratører, og hvilke typer input- og outputdata funksjonene dine kan håndtere.

SDK for brukerdatafunksjoner

SDK-en fabric-user-data-functions gir kjernekomponentene du trenger for å lage brukerdatafunksjoner i Python.

Påkrevde import og initialisering

Hver user data functions-fil må importere modulen fabric.functions og initialisere kjøringskonteksten:

import datetime
import fabric.functions as fn
import logging

udf = fn.UserDataFunctions()

Dekoratøren @udf.function()

Funksjoner merket med dekoratoren @udf.function() kan kalles fra Fabric-portalen, et annet Fabric-element eller en ekstern applikasjon. Funksjoner med denne dekoratoren må spesifisere en returtype.

Eksempel:

@udf.function()
def hello_fabric(name: str) -> str:
    logging.info('Python UDF trigger function processed a request.')
    logging.info('Executing hello fabric function.')
    
    return f"Welcome to Fabric Functions, {name}, at {datetime.datetime.now()}!"

Hjelper-funksjoner

Python-metoder uten @udf.function() decorator kan ikke aktiveres direkte. De kan kun tilkalles fra dekorerte funksjoner og fungerer som hjelpefunksjoner.

Eksempel:

def uppercase_name(name: str) -> str:
    return name.upper()

Støttede inndatatyper

Du kan definere inndataparametere for funksjonen, for eksempel primitive datatyper som str, int, float osv. Datatypene for inndata som støttes, er:

JSON-type Python-datatype
Streng Str
Datetime-streng datetime
Boolsk Bool
tall int, flyt
Matrise list[], eksempelliste[int]
objekt Diktering
objekt pandaer DataFrame
Objekt eller matrise av objekter pandas-serien

Merk deg

For å bruke pandas DataFrame- og Series-typer, gå til Fabric-portalen, finn arbeidsområdet ditt, og åpne brukerdatafunksjonene dine. Velg Biblioteksadministrasjon, søk etter fabric-user-data-functions pakken, og oppdater den til versjon 1.0.0 eller nyere.

Eksempel på forespørselstekst for inndatatyper som støttes:

{
  "name": "Alice",                          // String (str)
  "signup_date": "2025-11-08T13:44:40Z",    // Datetime string (datetime)
  "is_active": true,                        // Boolean (bool)
  "age": 30,                                // Number (int)
  "height": 5.6,                            // Number (float)
  "favorite_numbers": [3, 7, 42],           // Array (list[int])
  "profile": {                              // Object (dict)
    "email": "alice@example.com",
    "location": "Sammamish"
  },
  "sales_data": {                           // Object (pandas DataFrame)
    "2025-11-01": {"product": "A", "units": 10},
    "2025-11-02": {"product": "B", "units": 15}
  },
  "weekly_scores": [                        // Object or Array of Objects (pandas Series)
    {"week": 1, "score": 88},
    {"week": 2, "score": 92},
    {"week": 3, "score": 85}
  ]
}

Utdatatyper som støttes

Datatypene for utdata som støttes, er:

Python-datatype
Str
datetime
Bool
int, flyt
list[datatype], for eksempel liste[int]
Diktering
Ingen
pandas-serien
pandaer DataFrame

Skrivefunksjoner

Syntakskrav og begrensninger

Når du skriver User Data Functions, må du følge spesifikke syntaksregler for å sikre at funksjonene dine fungerer korrekt.

Parameternavngivning

  • Bruk camelCase: Parameternavn må bruke camelCase-navnekonvensjon og kan ikke inneholde understreker. For eksempel, bruk productName i stedet for product_name.
  • Reserverte nøkkelord: Du kan ikke bruke reserverte Python-nøkkelord eller følgende Fabric-spesifikke nøkkelord som parameternavn eller funksjonsnavn: req, context, og reqInvocationId.

Parameterkrav

  • Ingen standardverdier: Standardparameterverdier støttes ikke. Alle parametere er nødvendige når en funksjon skal utløses. For eksempel gir følgende funksjon en syntaksfeil:
    # The default value for the argument called 'name' is not supported and treated like a syntax error.
    @udf.function()
    def goodbye_fabric(name: str = "N/A") -> str:
        return f"Goodbye, {name}."
    
  • Typeannotasjoner som kreves: Alle parametere må inkludere typeannotasjoner (for eksempel name: str).

Funksjonskrav

  • Returtype kreves: Funksjoner med dekoratoren @udf.function() må spesifisere en returtypeannotasjon (for eksempel -> str).
  • Nødvendige importer: Setningen import fabric.functions as fn og udf = fn.UserDataFunctions() initialiseringen er nødvendige for at funksjonene dine skal fungere.

Eksempel på korrekt syntaks

@udf.function()
def process_order(orderNumber: int, customerName: str, orderDate: str) -> dict:
    return {
        "order_id": orderNumber,
        "customer": customerName,
        "date": orderDate,
        "status": "processed"
    }

Slik skriver du en asynkrone funksjon

Legg til asynkron dekoratør med funksjonsdefinisjonen i koden. Med en async funksjon kan du forbedre respons og effektivitet i programmet ved å håndtere flere oppgaver samtidig. De er ideelle for å håndtere store volumer av I/O-bundne operasjoner. Denne eksempelfunksjonen leser en CSV-fil fra et lakehouse ved hjelp av pandaer. Funksjonen tar filnavn som inndataparameter.

import pandas as pd 

# Replace the alias "<My Lakehouse alias>" with your connection alias.
@udf.connection(argName="myLakehouse", alias="<My Lakehouse alias>")
@udf.function()
async def read_csv_from_lakehouse(myLakehouse: fn.FabricLakehouseClient, csvFileName: str) -> str:

    # Connect to the Lakehouse
    connection = myLakehouse.connectToFilesAsync()   

    # Download the CSV file from the Lakehouse
    csvFile = connection.get_file_client(csvFileName)

    downloadFile = await csvFile.download_file()
    csvData = await downloadFile.readall()
    
    # Read the CSV data into a pandas DataFrame
    from io import StringIO
    df = pd.read_csv(StringIO(csvData.decode('utf-8')))

    # Display the DataFrame    
    result="" 
    for index, row in df.iterrows():
        result=result + "["+ (",".join([str(item) for item in row]))+"]"
    
    # Close the connection
    csvFile.close()
    connection.close()

    return f"CSV file read successfully.{result}"

Arbeid med data

Datatilkoblinger til Fabric-datakilder

SDK-en lar deg referere til dataforbindelser uten behov for å skrive tilkoblingsstrenger i koden din. Biblioteket fabric.functions inneholder to måter å håndtere datatilkoblinger på:

  • fabric.functions.FabricSqlConnection: Lar deg arbeide med SQL-databaser i Fabric, inkludert SQL Analytics-endepunkter og Fabric-lagre.
  • fabric.functions.FabricLakehouseClient: Lar deg jobbe med Lakehouses, med en måte å koble til både Lakehouse-bord og Lakehouse-filer.

Hvis du vil referere til en tilkobling til en datakilde, må du bruke @udf.connection-dekoratøren. Du kan bruke den i et av følgende formater:

  • @udf.connection(alias="<alias for data connection>", argName="sqlDB")
  • @udf.connection("<alias for data connection>", "<argName>")
  • @udf.connection("<alias for data connection>")

Argumentene for @udf.connection er:

  • argName, navnet på variabelen som tilkoblingen bruker i funksjonen.
  • alias, aliaset for tilkoblingen du la til med Behandle tilkoblinger-menyen.
  • Hvis argName og alias har samme verdi, kan du bruke @udf.connection("<alias and argName for the data connection>").

Eksempel

# Where demosqldatabase is the argument name and the alias for my data connection used for this function
@udf.connection("demosqldatabase")
@udf.function()
def read_from_sql_db(demosqldatabase: fn.FabricSqlConnection)-> list:
  # Connect to the SQL database
  connection = demosqldatabase.connect()
  cursor = connection.cursor()
  
  # Replace with the query you want to run
  query = "SELECT * FROM (VALUES ('John Smith', 31), ('Kayla Jones', 33)) AS Employee(EmpName, DepID);"
  
  # Execute the query
  cursor.execute(query)
  
  # Fetch all results
  results = cursor.fetchall()
  
  # Close the cursor and connection
  cursor.close()
  connection.close()
  
  return results

Generelle tilkoblinger for Fabric-elementer eller Azure-ressurser

SDK-en støtter generiske tilkoblinger som lar deg opprette tilkoblinger til Fabric-elementer eller Azure-ressurser ved å bruke din User Data Functions-eieridentitet. Denne funksjonen genererer et Microsoft Entra ID-token med elementeierens identitet og en angitt målgruppetype. Dette tokenet brukes til å godkjenne med Fabric-elementer eller Azure-ressurser som støtter denne målgruppetypen. Denne tilnærmingen gir en lignende programmeringsopplevelse som å bruke administrerte tilkoblingsobjekter fra funksjonen Administrer tilkoblinger , men kun for den oppgitte målgruppetypen i forbindelsen.

Denne funksjonen bruker dekoratøren @udf.generic_connection() med følgende parametere:

Parameter Beskrivelse Verdi
argName Navnet på variabelen som sendes til funksjonen. Brukeren må spesifisere denne variabelen i argumentene til funksjonen og bruke typen fn.FabricItem for den Hvis for eksempel argName=CosmosDb, skal funksjonen inneholde dette argumentet cosmosDb: fn.FabricItem
audienceType Målgruppetypen som tilkoblingen er opprettet for. Denne parameteren er knyttet til typen Fabric-element eller Azure-tjeneste og bestemmer klienten som brukes for tilkoblingen. De tillatte verdiene for denne parameteren er CosmosDb eller KeyVault.

Koble til Fabric Cosmos DB-beholder ved hjelp av en generisk tilkobling

Generelle tilkoblinger støtter opprinnelige Fabric Cosmos DB-elementer ved hjelp av målgruppetypen CosmosDB . Den inkluderte SDK-en for brukerdatafunksjoner gir en hjelpemetode kalt get_cosmos_client som henter en singleton Cosmos DB-klient for hvert anrop.

Du kan koble til et Fabric Cosmos DB-element ved hjelp av en generisk tilkobling ved å følge disse trinnene:

  1. Gå til Fabric-portalen, finn arbeidsområdet ditt, og åpne elementet for brukerdatafunksjoner. Velg Biblioteksadministrasjon, søk etter biblioteket azure-cosmos , og installer det. For mer informasjon, se Administrer biblioteker.

  2. Gå til elementinnstillingene for Fabric Cosmos DB .

    Skjermbilde som viser plasseringen av Fabric Cosmos DB-innstillingsknappen.

  3. Hent URL-adressen for Fabric Cosmos DB-endepunktet.

    Skjermbilde som viser URL-adressen for Fabric Cosmos DB-endepunktet.

  4. Gå til elementet Brukerdatafunksjoner. Bruk følgende eksempelkode til å koble til Fabric Cosmos DB-beholderen og kjøre en lesespørring ved hjelp av Cosmos DB-eksempeldatasettet. Erstatt verdiene for følgende variabler:

    • COSMOS_DB_URI med Fabric Cosmos DB-endepunktet.
    • DB_NAME med navnet på Fabric Cosmos DB-varen din.
    from fabric.functions.cosmosdb import get_cosmos_client
    import json
    
    @udf.generic_connection(argName="cosmosDb", audienceType="CosmosDB")
    @udf.function()
    def get_product_by_category(cosmosDb: fn.FabricItem, category: str) -> list:
    
        COSMOS_DB_URI = "YOUR_COSMOS_DB_URL"
        DB_NAME = "YOUR_COSMOS_DB_NAME" # Note: This is the Fabric item name
        CONTAINER_NAME = "SampleData" # Note: This is your container name. In this example, we are using the SampleData container.
    
        cosmosClient = get_cosmos_client(cosmosDb, COSMOS_DB_URI)
    
        # Get the database and container
        database = cosmosClient.get_database_client(DB_NAME)
        container = database.get_container_client(CONTAINER_NAME)
    
        query = 'select * from c WHERE c.category=@category' #"select * from c where c.category=@category"
        parameters = [
            {
                "name": "@category", "value": category
            }
        ]
        results = container.query_items(query=query, parameters=parameters)
        items = [item for item in results]
    
        logging.info(f"Found {len(items)} products in {category}")
    
        return json.dumps(items)
    
  5. Test eller kjør denne funksjonen ved å angi et kategorinavn, for eksempel Accessory i aktiveringsparameterne.

Merk deg

Du kan også bruke disse trinnene til å koble til en Azure Cosmos DB-database ved hjelp av nettadressen for kontoen og databasenavnene. User Data Functions-eierkontoen trenger tilgangstillatelser til den Azure Cosmos DB-kontoen.

Koble til Azure Key Vault ved hjelp av en generisk tilkobling

Generelle tilkoblinger støtter tilkobling til et Azure Key Vault ved hjelp av målgruppetypen KeyVault . Denne typen tilkobling krever at eieren av Fabric User Data Functions har tillatelse til å koble til Azure Key Vault. Du kan bruke denne tilkoblingen til å hente nøkler, hemmeligheter eller sertifikater etter navn.

Du kan koble til Azure Key Vault for å hente en klienthemmelighet for å kalle en API ved hjelp av en generell tilkobling ved å følge denne fremgangsmåten:

  1. Gå til Fabric-portalen, finn arbeidsområdet ditt, og åpne elementet for brukerdatafunksjoner. Velg Biblioteksadministrasjon, søk deretter etter og installer requests og-bibliotekene azure-keyvault-secrets . For mer informasjon, se Administrer biblioteker.

  2. Gå til Azure Key Vault-ressursen din i Azure-portalen og hent Vault URI navnet på nøkkelen, hemmeligheten eller sertifikatet ditt.

    Skjermbilde som viser URL-adressen og verdiene for Azure Key Vault-endepunktet.

  3. Gå tilbake til Fabric User Data Functions-elementet , og bruk dette eksemplet. I dette eksemplet henter vi en hemmelighet fra Azure Key Vault for å koble til en offentlig API. Erstatt verdien av følgende variabler:

    • KEY_VAULT_URL med du Vault URI hentet i forrige trinn.
    • KEY_VAULT_SECRET_NAME med navnet på hemmeligheten din.
    • API_URL variabelen med nettadressen til API-et du vil koble til. Dette eksemplet forutsetter at du kobler til en offentlig API som godtar GET-forespørsler og tar følgende parametere api-key og request-body.
    from azure.keyvault.secrets import SecretClient
    from azure.identity import DefaultAzureCredential
    import requests
    
    @udf.generic_connection(argName="keyVaultClient", audienceType="KeyVault")
    @udf.function()
    def retrieveNews(keyVaultClient: fn.FabricItem, requestBody:str) -> str:
        KEY_VAULT_URL = 'YOUR_KEY_VAULT_URL'
        KEY_VAULT_SECRET_NAME= 'YOUR_SECRET'
        API_URL = 'YOUR_API_URL'
    
        credential = keyVaultClient.get_access_token()
    
        client = SecretClient(vault_url=KEY_VAULT_URL, credential=credential)
    
        api_key = client.get_secret(KEY_VAULT_SECRET_NAME).value
    
        api_url = API_URL
        params = {
            "api-key": api_key,
            "request-body": requestBody
        }
    
        response = requests.get(api_url, params=params)
    
        data = "" 
    
        if response.status_code == 200:
            data = response.json()
        else:
            print(f"Error {response.status_code}: {response.text}")
    
        return f"Response: {data}"
    
  4. Test eller kjør denne funksjonen ved å angi en forespørselstekst i koden.

Avanserte funksjoner

Programmeringsmodellen definerer avanserte mønstre som gir deg større kontroll over funksjonene dine. SDK-en implementerer disse mønstrene gjennom klasser og metoder som lar deg å:

  • Få tilgang til invokasjonsmetadata om hvem som kalte funksjonen din og hvordan
  • Håndter tilpassede feilscenarier med strukturerte feilresponser
  • Integrer med Fabric-variabelbiblioteker for sentralisert konfigurasjonsstyring

Merk deg

User Data Functions har tjenestebegrensninger for forespørselsstørrelse, utførelsestidsavbrudd og svarstørrelse. For detaljer om disse begrensningene og hvordan de håndheves, se Tjenestedetaljer og begrensninger.

Hent aktiveringsegenskaper ved hjelp av UserDataFunctionContext

SDK-en inkluderer objektet UserDataFunctionContext . Dette objektet inneholder metadata for funksjonskall og kan brukes til å lage spesifikk app-logikk for ulike kallmekanismer (som portalkall versus REST API-kall).

Tabellen nedenfor viser egenskapene for objektet UserDataFunctionContext:

Egenskapsnavn Datatype Beskrivelse
invocation_id streng Den unike GUID-en som er knyttet til aktiveringen av elementet for brukerdatafunksjoner.
executing_user objekt Metadata for brukerens informasjon som brukes til å godkjenne aktiveringen.

Objektet executing_user inneholder følgende informasjon:

Egenskapsnavn Datatype Beskrivelse
Oid streng (GUID) Brukerens objekt-ID, som er en uforanderlig identifikator for anmoderen. Dette er den bekreftede identiteten til brukeren eller tjenestekontohaveren som brukes til å aktivere denne funksjonen på tvers av programmer.
TenantId streng (GUID) ID-en til leieren som brukeren er logget på.
PreferredUsername streng Foretrukket brukernavn for den påkallende brukeren, som angitt av brukeren. Denne verdien kan dempes.

Hvis du vil ha tilgang til UserDataFunctionContext-parameteren, må du bruke følgende dekoratør øverst i funksjonsdefinisjonen: @udf.context(argName="<parameter name>")

Eksempel

@udf.context(argName="myContext")
@udf.function()
def getContext(myContext: fabric.functions.UserDataFunctionContext)-> str:
    logging.info('Python UDF trigger function processed a request.')
    return f"Hello oid = {myContext.executing_user['Oid']}, TenantId = {myContext.executing_user['TenantId']}, PreferredUsername = {myContext.executing_user['PreferredUsername']}, InvocationId = {myContext.invocation_id}"

Kast en håndtert feil med UserThrownError

Når du utvikler funksjonen din, kan du kaste et forventet feilsvar ved å bruke UserThrownError klassen som er tilgjengelig i SDK-en. En bruk av denne klassen er å håndtere tilfeller der brukerinndataene ikke klarer å bestå forretningsvalideringsreglene.

Eksempel

import datetime

@udf.function()
def raise_userthrownerror(age: int)-> str:
    if age < 18:
        raise fn.UserThrownError("You must be 18 years or older to use this service.", {"age": age})

    return f"Welcome to Fabric Functions at {datetime.datetime.now()}!"

Klassekonstruktøren UserThrownError tar to parametere:

  • Message: Denne strengen returneres som feilmelding til programmet som aktiverer denne funksjonen.
  • En ordliste med egenskaper returneres til programmet som aktiverer denne funksjonen.

Hent variabler fra Fabric-variabelbiblioteker

Et Fabric-variabelbibliotek i Microsoft Fabric er et sentralisert arkiv for å administrere variabler som kan brukes på tvers av ulike elementer i et arbeidsområde. Det lar utviklere tilpasse og dele varekonfigurasjoner effektivt. Hvis du ikke har et variabelbibliotek ennå, se Opprett og administrer variabelbiblioteker.

For å bruke et variabelbibliotek i funksjonene dine, legger du til en tilkobling til det fra brukerdatafunksjonene dine. Variabelbiblioteker finnes i OneLake-katalogen sammen med datakilder som SQL-databaser og lakehouses.

Følg disse stegene for å bruke variabelbiblioteker i funksjonene dine:

  1. I brukerdatafunksjonene dine, legg til en tilkobling til variabelbiblioteket ditt. I OneLake-katalogen, finn og velg variabelbiblioteket ditt, og velg deretter Koble til. Legg merke til aliaset som Fabric genererer for tilkoblingen.
  2. Legg til en tilkoblingsdekorator for det variable bibliotekelementet. Du kan for eksempel @udf.connection(argName="varLib", alias="<My Variable Library Alias>") erstatte alias til den nylig tilføyde tilkoblingen for det variable bibliotekelementet.
  3. I funksjonsdefinisjonen tar du med et argument med typen fn.FabricVariablesClient. Denne klienten inneholder metoder du trenger for å arbeide med variabelbibliotekelementet.
  4. Bruk getVariables() metoden for å hente alle variablene fra variabelbiblioteket.
  5. For å lese verdiene til variablene bruker du enten ["variable-name"] eller .get("variable-name").

Eksempel

I dette eksempelet simulerer vi et konfigurasjonsscenario for et produksjons- og et utviklingsmiljø. Denne funksjonen angir en lagringsbane avhengig av det valgte miljøet ved hjelp av en verdi hentet fra variabelbiblioteket. Variabelbiblioteket inneholder en variabel kalt ENV der brukere kan angi en verdi på dev eller prod.

@udf.connection(argName="varLib", alias="<My Variable Library Alias>")
@udf.function()
def get_storage_path(dataset: str, varLib: fn.FabricVariablesClient) -> str:
    """
    Description: Determine storage path for a dataset based on environment configuration from Variable Library.
    
    Args:
        dataset_name (str): Name of the dataset to store.
        varLib (fn.FabricVariablesClient): Fabric Variable Library connection.
    
    Returns:
        str: Full storage path for the dataset.
    """
    # Retrieve variables from Variable Library
    variables = varLib.getVariables()
    
    # Get environment and base paths
    env = variables.get("ENV")    
    dev_path = variables.get("DEV_FILE_PATH")
    prod_path = variables.get("PROD_FILE_PATH")
    
    # Apply environment-specific logic
    if env.lower() == "dev":
        return f"{dev_path}{dataset}/"
    elif env.lower() == "prod":
        return f"{prod_path}{dataset}/"
    else:
        return f"incorrect settings define for ENV variable"