Skapa variabler för att lagra och hantera värden i Azure Logic Apps
Gäller för: Azure Logic Apps (Förbrukning + Standard)
Den här instruktionsguiden visar hur du skapar och arbetar med variabler så att du kan lagra och använda värden i logikappens arbetsflöde. Variabler kan till exempel hjälpa dig att spåra antalet gånger som en loop körs. Om du vill iterera över en matris eller kontrollera en matris för ett visst objekt kan du använda en variabel för att referera till indexnumret för varje matrisobjekt.
Du kan skapa variabler för datatyper som heltal, flyttal, boolesk, sträng, matris och objekt. När du har skapat en variabel kan du utföra andra uppgifter, som:
- Hämta eller referera till variabelns värde.
- Öka eller minska variabeln med ett konstant värde, även kallat ökning och minskning.
- Tilldela ett annat värde till variabeln.
- Infoga eller lägga till variabelns värde som det sista objektet i en sträng eller matris.
Variabler finns och är endast globala i arbetsflödesinstansen som skapar dem. Dessutom finns de kvar i alla loop-iterationer i en arbetsflödesinstans. När du refererar till en variabel använder du variabelns namn som token, inte åtgärdens namn, vilket är det vanliga sättet att referera till en åtgärds utdata.
Viktigt!
Som standard körs iterationerna i en För varje loop parallellt. När du använder variabler i loopar kör du loopen sekventiellt så att variablerna returnerar förutsägbara resultat.
Förutsättningar
Ett Azure-konto och prenumeration. Om du inte har en prenumeration registrerar du dig för ett kostnadsfritt Azure-konto.
Ett arbetsflöde för logikappen där du vill skapa variabeln och en utlösare som startar arbetsflödet.
Innan du kan lägga till åtgärder för att skapa och arbeta med variabler måste arbetsflödet börja med en utlösare som det första steget i arbetsflödet. Mer information finns i Skapa ett arbetsflöde med en utlösare eller åtgärd.
Följande steg använder Azure Portal, men med rätt Azure Logic Apps-tillägg kan du också använda följande verktyg för att skapa arbetsflöden för logikappar:
- Förbrukningsarbetsflöden: Visual Studio Code
- Standardarbetsflöden: Visual Studio Code
Baserat på om du har ett förbruknings- eller standardarbetsflöde följer du motsvarande steg:
Initiera variabel
Du kan skapa en variabel och deklarera dess datatyp och initialvärde med hjälp av en enda åtgärd i arbetsflödet. Du kan endast ange variabler på global nivå, inte inom omfattningar, villkor och loopar.
Öppna arbetsflödet i designern i Azure Portal.
I designern följer du de här allmänna stegen för att lägga till en åtgärd med namnet Initiera variabel.
Ange följande information om din variabel:
Property Obligatoriskt Värde Beskrivning Namn Ja <variabelnamn> Namn på variabel att öka Typ Ja <variabeltyp> Datatypen för variabeln Värde No <startvärde> Det initiala värdet för variabeln
Tips: Även om det är valfritt anger du värdet som bästa praxis så att du alltid vet din variabels startvärde.I följande exempel visas de inledande värdena för den här exempelvariabeln:
Fortsätt nu att lägga till de åtgärder som du vill ha för ditt scenario. När du är klar klickar du på tabelldesignern Spara på kommandofältet.
Om du växlar från designern till kodvyn visar följande exempel hur åtgärden Initiera variabel visas i arbetsflödesdefinitionen, som är i JSON-format (JavaScript Object Notation):
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "Count",
"type": "Integer",
"value": 0
}
]
},
"runAfter": {}
}
},
Kommentar
Även om åtgärden Initiera variabel har ett "variables"
objekt som är strukturerat som en matris, kan åtgärden bara skapa en variabel i taget. För varje ny variabel krävs en enskild åtgärd för variabeln Initiera variabeln.
I följande exempel visas andra variabeltyper:
Boolesk variabel
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "myBooleanVariable",
"type": "boolean",
"value": false
}
]
},
"runAfter": {}
}
},
Flyttalvariabel
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "myFloatVariable",
"type": "float",
"value": 1.99999
}
]
},
"runAfter": {}
}
},
Strängvariabel
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "myStringVariable",
"type": "string",
"value": "lorem ipsum"
}
]
},
"runAfter": {}
}
},
Objektvariabel
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "MyObjectVariable",
"type": "object",
"value": {
"ProductItem": {
"Name": "myProductName",
"ProductID": "000000"
}
}
}
]
},
"runAfter": {}
}
},
Matris med heltal
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "myArrayVariable",
"type": "array",
"value": [1, 2, 3]
}
]
},
"runAfter": {}
}
},
Matris med strängar
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [
{
"name": "myArrayVariable",
"type": "array",
"value": ["red", "orange", "yellow"]
}
]
},
"runAfter": {}
}
},
Hämta en variabels värde
Om du vill hämta eller referera till en variabels innehåll kan du använda funktionen variables() i arbetsflödesdesignern och kodvisningsredigeraren. När du refererar till en variabel använder du variabelns namn som token, inte åtgärdens namn, vilket är det vanliga sättet att referera till en åtgärds utdata.
Följande uttryck hämtar till exempel objekten från matrisvariabeln som skapas i den här guiden med hjälp variables()
av funktionen. Funktionen string()
returnerar variabelns innehåll i strängformat: "1, 2, 3, red"
@{string(variables('myArrayVariable'))}
Öka variabel
Om du vill öka eller öka en variabel med ett specifikt konstant värde lägger du till åtgärden Öka variabel i arbetsflödet. Den här åtgärden fungerar endast med heltals- och flyttalsvariabler.
I arbetsflödesdesignern följer du de här allmänna stegen för att lägga till en åtgärd med namnet Inkrementsvariabel.
Ange följande information för den här åtgärden:
Property Obligatoriskt Värde Beskrivning Namn Ja <variabelnamn> Namn på variabel att öka Värde Nej <öka värde> Värdet som används för att öka variabeln. Standardvärdet är 1
.
Tips: Även om det är valfritt anger du det här värdet som bästa praxis så att du alltid vet det specifika värdet för att öka variabeln.I följande exempel visas exempelvärdena för den här åtgärden:
Spara arbetsflödet när du är klar. I verktygsfältet för designern väljer du Spara.
Om du växlar från designern till kodvyn visar följande exempel hur åtgärden Öka variabel visas i arbetsflödesdefinitionen, som är i JSON-format:
"actions": {
"Increment_variable": {
"type": "IncrementVariable",
"inputs": {
"name": "Count",
"value": 1
},
"runAfter": {}
}
},
Exempel: Skapa loopräknare
Variabler används ofta för att räkna antalet gånger som en loop körs. Det här exemplet visar hur du kan skapa och använda variabler för den här uppgiften genom att skapa en loop som räknar de bifogade filerna i ett e-postmeddelande.
I Azure Portal skapar du din förbrukningslogikappresurs med ett tomt arbetsflöde. Lägg till en utlösare som söker efter ny e-post och eventuella bifogade filer.
I det här exemplet används Office 365 Outlook-utlösaren När ett nytt e-postmeddelande kommer. Du kan endast ställa in den här utlösaren så att den aktiveras om e-postmeddelandet innehåller bifogade filer. Du kan dock använda vilket anslutningsprogram som helst som söker efter nya e-postmeddelanden med bifogade filer, till exempel Outlook.com anslutaren.
I utlösaren väljer du Ja för följande egenskaper för att söka efter bifogade filer och skicka de bifogade filerna till arbetsflödet:
- Endast med bifogad fil
- Inkludera bifogade filer
Lägg till åtgärden Initiera variabel för att skapa en heltalsvariabel med namnet Count som har ett startvärde inställt på
0
.Om du vill iterera genom varje bifogad fil följer du de här allmänna stegen för att lägga till en åtgärd som kallas för en För varje loop.
I loopen väljer du i rutan Med namnet Välj utdata från föregående steg. När listan med dynamiskt innehåll visas väljer du Bifogade filer under När ett nytt e-postmeddelande kommer.
Egenskapen Attachments skickar en matris som innehåller e-postbilagor från utlösarens utdata till loopen för arbetsflödet att iterera över.
I loopen För varje väljer du Lägg till en åtgärd.
-
Kommentar
Kontrollera att åtgärden Öka variabel visas i loopen. Om åtgärden visas utanför loopen drar du åtgärden till loopen.
I åtgärden Ökningsvariabel från listan Namn, välj variabeln Antal. Ange egenskapen Value till
1
.Lägg till alla åtgärder som skickar antalet bilagor under loop. Ta med värdet från din åtgärd Antal till exempel:
Spara arbetsflödet när du är klar. I verktygsfältet för designern väljer du Spara.
Testa arbetsflödet
Om du vill utlösa arbetsflödet manuellt följer du motsvarande steg:
Arbetsflöde för förbrukning
I verktygsfältet för designerarbetsflödet väljer du Kör utlösarkörning> för att köra arbetsflödet manuellt.
Standardarbetsflöde
På arbetsflödesmenyn väljer du Översikt. Välj Kör>kör i verktygsfältet.
Skicka ett e-postmeddelande med en eller flera bifogade filer till det e-postkonto som du använde i det här exemplet.
Det här steget utlöser arbetsflödesutlösaren, som skapar och kör en arbetsflödesinstans. Därför skickar arbetsflödet ett meddelande eller ett e-postmeddelande som visar antalet bifogade filer i e-postmeddelandet som du skickade.
Om du växlar från designern till kodvyn visar följande exempel hur för varje loop visas tillsammans med åtgärden Öka variabel i arbetsflödesdefinitionen, som är i JSON-format:
"actions": {
"For_each": {
"type": "Foreach",
"actions": {
"Increment_variable": {
"type": "IncrementVariable",
"inputs": {
"name": "Count",
"value": 1
},
"runAfter": {}
}
},
"foreach": "@triggerBody()?['Attachments']",
"runAfter": {
"Initialize_variable": [ "Succeeded" ]
}
}
},
Minskningsvariabel
Om du vill minska eller minska en variabel med ett specifikt konstant värde följer du stegen för att öka en variabel , förutom att du lägger till åtgärden Decrement variable i arbetsflödet i stället. Den här åtgärden fungerar endast med heltals- och flyttalsvariabler.
I följande tabell beskrivs informationen för åtgärden decrementvariabel :
Property | Obligatoriskt | Värde | Beskrivning |
---|---|---|---|
Namn | Ja | <variabelnamn> | Namn på variabel att minska |
Värde | Nej | <öka värde> | Värdet för att minska variabeln. Standardvärdet är ett. Tips: Även om det är valfritt, ställ in detta värde som en bästa praxis så känna till det specifika värdet för att minska din variabel. |
Om du växlar från designern till kodvyn visar följande exempel hur åtgärden decrementvariabel visas i arbetsflödesdefinitionen, som är i JSON-format:
"actions": {
"Decrement_variable": {
"type": "DecrementVariable",
"inputs": {
"name": "Count",
"value": 1
},
"runAfter": {}
}
},
Ange variabel
Om du vill tilldela ett annat värde till en befintlig variabel följer du stegen för att öka en variabel med följande undantag:
Hitta och välj åtgärden ange variabel istället.
Ange det variabelnamn och värde du vill tilldela. Både det nya värdet och variabeln måste ha samma datatyp. Värdet krävs eftersom den här åtgärden inte har något standardvärde.
I följande tabell beskrivs informationen för åtgärden Ange variabel :
Property | Obligatoriskt | Värde | Beskrivning |
---|---|---|---|
Namn | Ja | <variabelnamn> | Namn på variabel att ändra |
Värde | Ja | <nytt värde> | Värdet du vill tilldela variabeln. Båda måste ha samma datatyp. |
Kommentar
Om du inte ökar eller minskar variabler kan ändrade variabler i loopar skapa oväntade resultat eftersom loopar körs parallellt eller samtidigt som standard. I dessa fall kan du prova att ange att loopen ska köras sekventiellt. Om du till exempel vill referera till variabelvärdet i loopen och förvänta dig samma värde i början och slutet av loopinstansen följer du dessa steg för att ändra hur loopen körs:
Leta upp och öppna loopinställningarna i loopen.
Följ motsvarande steg baserat på din arbetsflödestyp:
Förbrukning: Ändra inställningen Samtidighetskontroll från Av till På.
Standard: Ändra inställningen Samtidighetskontroll från Av till På under Allmänt.
Dra skjutreglaget Grad av parallellitet till 1.
Om du växlar från designern till kodvyn visar följande exempel hur åtgärden Ange variabel visas i arbetsflödesdefinitionen, som är i JSON-format:
I följande exempel ändras Count
variabelns aktuella värde till ett annat värde:
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [ {
"name": "Count",
"type": "Integer",
"value": 0
} ]
},
"runAfter": {}
},
"Set_variable": {
"type": "SetVariable",
"inputs": {
"name": "Count",
"value": 100
},
"runAfter": {
"Initialize_variable": [ "Succeeded" ]
}
}
},
Lägga till variabel
För variabler som lagrar strängar eller matriser kan du infoga eller lägga till en variabels värde som det sista objektet i de strängarna eller matriserna. Du kan följa stegen för att öka en variabel med följande undantag:
Leta upp och välj en av dessa åtgärder baserat på om din variabel är en sträng eller en matris:
- Lägga till strängvariabel
- Lägga till matrisvariabel
Ange värdet som ska läggas till som det sista objektet i strängen eller matrisen. Detta värde krävs.
I följande tabell beskrivs informationen för åtgärderna Lägg till i ... :
Property | Obligatoriskt | Värde | Beskrivning |
---|---|---|---|
Namn | Ja | <variabelnamn> | Namn på variabel att ändra |
Värde | Ja | <lägga till värde> | Värdet du vill lägga till, vilket kan ha valfri typ |
Om du växlar från designern till kodvyn visar följande exempel hur åtgärden Lägg till i matrisvariabel visas i arbetsflödesdefinitionen, som är i JSON-format.
I följande exempel skapas en matrisvariabel och ett annat värde läggs till som det sista objektet i matrisen. Resultatet är en uppdaterad variabel som innehåller den här matrisen: [1,2,3,"red"]
"actions": {
"Initialize_variable": {
"type": "InitializeVariable",
"inputs": {
"variables": [ {
"name": "myArrayVariable",
"type": "Array",
"value": [1, 2, 3]
} ]
},
"runAfter": {}
},
"Append_to_array_variable": {
"type": "AppendToArrayVariable",
"inputs": {
"name": "myArrayVariable",
"value": "red"
},
"runAfter": {
"Initialize_variable": [ "Succeeded" ]
}
}
},