Anteckning
Å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.
Gäller för: Azure Logic Apps (Förbrukning + Standard)
Om du vill upprepa åtgärder i ett logikapparbetsflöde kan du lägga till loopen För varje loop eller Tills i arbetsflödet baserat på behoven för ditt scenario.
Kommentar
Letar du efter Power Automate-dokumentation om loopar? Se Använda loopar.
Baserat på ditt användningsfall kan du välja mellan följande typer av loopåtgärder:
- Om du vill upprepa en eller flera åtgärder för objekt i en matris eller samling lägger du till åtgärden För varje i arbetsflödet. - Om du har en utlösare som kan hantera matriser och vill köra en arbetsflödesinstans för varje matrisobjekt kan du också dela upp matrisen genom att ange utlösarens egenskap 'Dela på'. 
- Om du vill upprepa en eller flera åtgärder tills ett villkor uppfylls eller ett visst tillstånd ändras lägger du till åtgärden Till i arbetsflödet. - Arbetsflödet kör först alla åtgärder i loopen och kontrollerar sedan villkoret eller tillståndet. Om villkoret uppfylls stoppas loopen. Annars upprepas loopen. För standard- och maxgränser för antalet Until-loopar som ett arbetsflöde kan ha, se Begränsningar för samtidighet, loopning och utfasning. 
Förutsättningar
- Ett Azure-konto och prenumeration. Om du inte har någon prenumeration kan du registrera ett kostnadsfritt Azure-konto. 
- En logikappresurs där du kan skapa och redigera ett arbetsflöde. Se Vad är Azure Logic Apps. 
- Logikappens resurs och arbetsflöde där du vill upprepa en åtgärd i en loop och en utlösare som startar arbetsflödet. - Innan du kan lägga till en loopåtgärd måste arbetsflödet börja med en utlösare som första steg. Mer information finns i Lägga till en utlösare eller åtgärd för att skapa ett arbetsflöde. 
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
Vissa steg skiljer sig något beroende på om du har ett förbruknings- eller standardarbetsflöde.
För varje
Åtgärden För varje fungerar bara på matriser. Den här loopen upprepar en eller flera åtgärder för varje objekt i en matris. Granska följande överväganden för åtgärden För varje åtgärd:
- Åtgärden För varje kan bearbeta ett begränsat antal matrisobjekt. Den här gränsen finns i Begränsningar för samtidighet, loopning och utfasning. 
- Som standard körs cyklerna eller iterationerna i en För varje åtgärd samtidigt parallellt. - Det här beteendet skiljer sig från Power Automate's Apply för varje loop där iterationer körs en i taget eller sekventiellt. Om ditt användningsfall kräver sekventiell bearbetning kan du konfigurera För varje iterationer att köra en i taget. Om du till exempel vill pausa nästa iteration i en För varje åtgärd med hjälp av åtgärden Fördröjning måste du konfigurera varje iteration så att den körs sekventiellt. - Ett undantag från standardbeteendet är att en kapslad för varje åtgärds iterationer alltid körs sekventiellt, inte parallellt. Om du vill köra åtgärder samtidigt på matrisobjekt i en kapslad för varje åtgärd skapar och anropar du ett underordnat arbetsflöde. 
- Kör iterationerna sekventiellt för att få förutsägbara resultat från åtgärder på variabler under varje iteration. När en iteration som körs samtidigt slutar returnerar variabeln Increment, Decrement variable och Append to variable operations förutsägbara resultat. Men under varje iteration i loopen som körs samtidigt kan dessa åtgärder returnera oförutsägbara resultat. 
- Åtgärder i en För varje loop använder - item()funktionen för att referera till och bearbeta varje objekt i matrisen. Om du anger data som inte finns i en matris misslyckas arbetsflödet.
I följande exempelarbetsflöde skickas en daglig sammanfattning för en webbplats RSS-feed. Arbetsflödet använder en För varje åtgärd som skickar ett e-postmeddelande för varje nytt objekt.
- I Azure-portalen skapar du ett arbetsflöde för logikappen med följande steg i den angivna ordningen: - RSS-utlösaren med namnet När ett flödesobjekt publiceras - Följ de här allmänna stegen för att lägga till en utlösare i ett arbetsflöde för förbrukning eller standardlogikapp . 
- Åtgärden Outlook.com eller Office 365 Outlook med namnet Skicka ett e-postmeddelande - Följ dessa allmänna steg för att lägga till en åtgärd i ett arbetsflöde för förbrukning eller standardlogikapp . 
 
- Följ samma allmänna steg för att lägga till åtgärden För varje mellan RSS-utlösaren och Skicka en e-poståtgärd i arbetsflödet. 
- Skapa nu loopen: - I rutan För varje objekt väljer du i rutan Välj utdata från föregående steg och väljer sedan blixtikonen. 
- I listan med dynamiskt innehåll som öppnas under När ett flödesobjekt publiceras väljer du Feed-länkar, vilket är en matrisutdata från RSS-utlösaren. - Kommentar - Om feedlänkarnainte visas bredvid utlösaravsnittsetiketten väljer du Visa mer. I listan med dynamiskt innehåll kan du bara välja utdata från föregående steg. - När du är klar visas de valda matrisutdata som i följande exempel:   
- Om du vill köra en befintlig åtgärd för varje matrisobjekt drar du åtgärden Skicka ett e-postmeddelande till för varje loop. - Nu ser arbetsflödet ut som i följande exempel:   
 
- Spara arbetsflödet när du är klar. 
- Om du vill testa arbetsflödet manuellt går du till verktygsfältet designer och väljer Kör>kör. 
För varje åtgärdsdefinition (JSON)
Om du arbetar i kodvyn kan du definiera For_each åtgärden i arbetsflödets JSON-definition, till exempel:
"actions": {
   "For_each": {
      "actions": {
         "Send_an_email_(V2)": {
            "type": "ApiConnection",
            "inputs": {
               "body": {
                  "Body": "@{item()}",
                  "Subject": "New CNN post @{triggerBody()?['publishDate']}",
                  "To": "me@contoso.com"
               },
               "host": {
                  "connection": {
                     "name": "@parameters('$connections')['office365']['connectionId']"
                  }
               },
               "method": "post",
               "path": "/v2/Mail"
            },
            "runAfter": {}
         }
      },
      "foreach": "@triggerBody()?['links']",
      "runAfter": {},
      "type": "Foreach"
   }
},
För varje: Kör sekventiellt
Som standard körs iterationerna i en För varje åtgärd samtidigt parallellt. Men om du har kapslade loopar eller har variabler inuti loopar där du förväntar dig förutsägbara resultat, måste du köra dessa loopar en i taget sekventiellt.
- I designern väljer du åtgärden För varje för att öppna informationsfönstret och väljer sedan Inställningar. 
- Under Samtidighetskontroll ändrar du inställningen från Av till På. 
- Flytta skjutreglaget grad av parallellitet till 1.   
För varje åtgärdsdefinition (JSON): Kör sekventiellt
Om du arbetar i kodvyn med For_each åtgärden i arbetsflödets JSON-definition lägger du till parametern operationOptions och anger parametervärdet till Sequential:
"actions": {
   "For_each": {
      "actions": {
         "Send_an_email_(V2)": { }
      },
      "foreach": "@triggerBody()?['links']",
      "runAfter": {},
      "type": "Foreach",
      "operationOptions": "Sequential"
   }
}
Do Until
Till-åtgärden körs och upprepar en eller flera åtgärder tills det angivna villkoret är uppfyllt. Om villkoret uppfylls stoppas loopen. Annars upprepas loopen. Standard- och maxgränser för antalet Till-åtgärder eller iterationer finns i Begränsningar för samtidighet, loopning och utfasning.
Följande lista innehåller några vanliga scenarier där du kan använda en Until-åtgärd :
- Anropa en slutpunkt tills du får det svar du vill ha. 
- Skapa en post i en databas. Vänta tills ett visst fält i posten godkänns. Fortsätt bearbetningen. 
Som standard lyckas eller misslyckas tills-åtgärden på följande sätt:
- Until-loopen lyckas om alla åtgärder i loopen lyckas och om loopgränsen nås, baserat på beteendet efter körning. 
- Om alla åtgärder i den senaste iterationen av Until-loopen lyckas markeras hela Until-loopen som Lyckades. 
- Om någon åtgärd misslyckas i den sista iterationen av Until-loopenmarkeras hela Until-loopen som Misslyckad. 
- Om någon åtgärd misslyckas i en annan iteration än den senaste iterationen fortsätter nästa iteration att köras och hela till-åtgärden markeras inte som Misslyckad. - Om du vill att åtgärden ska misslyckas i stället ändrar du standardbeteendet i loopens JSON-definition genom att lägga till parametern med namnet - operationOptionsoch ange värdet till , till- FailWhenLimitsReachedexempel:- "Until": { "actions": { "Execute_stored_procedure": { <...> } }, "expression": "@equals(variables('myUntilStop'), true)", "limit": { "count": 5, "timeout": "PT1H" }, "operationOptions": "FailWhenLimitsReached", "runAfter": { "Initialize_variable_8": [ "Succeeded" ] }, "type": "Until" }
I följande exempelarbetsflöde, som börjar kl. 08:00 varje dag, ökar åtgärden Until en variabel tills variabelns värde är lika med 10. Arbetsflödet skickar sedan ett e-postmeddelande som bekräftar det aktuella värdet. I exemplet används Office 365 Outlook, men du kan använda valfri e-postprovider som Azure Logic Apps stöder. Om du använder ett annat e-postkonto förblir de allmänna stegen desamma, men de ser lite annorlunda ut.
- I Azure-portalen skapar du en logikappresurs med ett tomt arbetsflöde. Se den tidigare proceduren. 
- I designern följer du de allmänna stegen för att lägga till den inbyggda utlösaren Schema med namnet Återkommande i arbetsflödet för förbrukning eller standard . 
- I utlösaren Upprepning anger du intervallet, frekvensen och tiden för utlösaren att utlösaren utlöses. - Parameter - Värde - Intervall - 1 - Frekvens - dag - Vid dessa timmar - 8 - Vid dessa minuter - 00 - Vid dessa tider och Vid dessa minuter visas när du har angett Frekvens till Dag. - När du är klar ser upprepningsutlösaren ut som i följande exempel:   
- Under utlösaren följer du de här allmänna stegen för att lägga till den inbyggda åtgärden Variabler med namnet Initialisera variabler i arbetsflödet för förbrukning eller standardlogikapp . 
- I åtgärden Initiera variabler anger du följande värden: - Parameter - Värde - Beskrivning - Namn - Gräns - Variabelns namn - Typ - Heltal - Din variabels datatyp - Värde - 0 - Variabelns startvärde 
- Under åtgärden Initiera variabler följer du dessa allmänna steg för att lägga till den inbyggda åtgärden Kontroll med namnet Until to your Consumption or Standard logic app workflow ( Kontrollera inbyggd åtgärd med namnet Until to your Consumption or Standard logic app workflow). 
- I åtgärden Till anger du följande värden för att konfigurera stoppvillkoret för loopen. - Välj i rutan Loopa till och välj blixtikonen för att öppna listan med dynamiskt innehåll. 
- I listan under Variabler väljer du variabeln Med namnet Gräns. 
- Under Antal anger du 10 som jämförelsevärde. 
 
- I åtgärden Till väljer du +>Lägg till en åtgärd. 
- Följ de här allmänna stegen för att lägga till den inbyggda åtgärden Variabler med namnet Increment variable (Öka variabel ) i åtgärden Until (Till ) i arbetsflödet för din förbrukning eller standardlogikapp . 
- I åtgärden Öka variabel anger du följande värden för att öka värdet för gränsvariabeln med 1: - Parameter - Värde - Gräns - Välj variabeln Gräns . - Värde - 1 
- Utanför och under åtgärden Till följer du dessa allmänna steg för att lägga till en åtgärd som skickar e-post i arbetsflödet för förbruknings- eller standardlogikappen. - Det här exemplet fortsätter med office 365 Outlook-åtgärden med namnet Skicka ett e-postmeddelande. 
- Ange följande värden i e-poståtgärden: - Parameter - Värde - Beskrivning - till - < e-address@domain> - Mottagarens e-postadress. Använd din egen e-postadress för testning. - Ämne - Aktuellt värde för variabeln "Gräns" är:Gräns - E-postämnet. I det här exemplet kontrollerar du att du inkluderar variabeln Gräns för att bekräfta att det aktuella värdet uppfyller ditt angivna villkor: 
 1. Välj i rutan Ämne och välj sedan blixtikonen.
 2. Välj Visa mer i listan med dynamiskt innehåll som öppnas bredvid avsnittet Variabler.
 3. Välj Gräns.- Brödtext - < e-postinnehåll> - E-postmeddelandets innehåll som du vill skicka. I det här exemplet anger du vilken text du vill. - När du är klar ser e-poståtgärden ut ungefär som i följande exempel: 
- Spara arbetsflödet. 
Testa arbetsflödet
Så här testar du logikappens arbetsflöde manuellt:
- I designerverktygsfältet går du till alternativet Kör och väljer Kör.
När arbetsflödet har börjat köras får du ett e-postmeddelande med det innehåll som du har angett:
              
               
              
              
            
Förhindra oändliga loopar
Åtgärden Till stoppar körningen baserat på de valfria parametrarna Antal och Tidsgräns . Kontrollera att du anger dessa parametervärden i enlighet med detta:
| Parameter | Beskrivning | 
|---|---|
| Antal | Det maximala antalet iterationer som körs innan loopen avslutas. För standard- och maxgränser för antalet Till-åtgärder som ett arbetsflöde kan ha, se Begränsningar för samtidighet, loopning och utfasning. | 
| Tidsgräns | Den maximala tid som till-åtgärden , inklusive alla iterationer, körs innan loopen avslutas. Det här värdet anges i ISO 8601-format och utvärderas för varje iteration. Om någon åtgärd i loopen tar längre tid än tidsgränsen stoppas inte den aktuella iterationen. Nästa iteration startar dock inte eftersom tidsgränsvillkoret är uppfyllt. Standard- och maxgränser för tidsgränsvärdetfinns i Begränsningar för samtidighet, loopning och utfasning. | 
"Until"-definition (JSON)
Om du arbetar i kodvyn kan du definiera en Until åtgärd i arbetsflödets JSON-definition, till exempel:
"actions": {
   "Initialize_variable": {
      // Definition for initialize variable action
   },
   "Send_an_email": {
      // Definition for send email action
   },
   "Until": {
      "type": "Until",
      "actions": {
         "Increment_variable": {
            "type": "IncrementVariable",
            "inputs": {
               "name": "Limit",
               "value": 1
            },
            "runAfter": {}
         }
      },
      "expression": "@equals(variables('Limit'), 10)",
      // To prevent endless loops, an "Until" loop 
      // includes these default limits that stop the loop. 
      "limit": { 
         "count": 60,
         "timeout": "PT1H"
      },
      "runAfter": {
         "Initialize_variable": [
            "Succeeded"
         ]
      }
   }
}
I det här exemplet anropar Until-loopen en HTTP-slutpunkt som skapar en resurs. Loopen stoppas när HTTP-svarstexten returneras med Completed status. För att förhindra oändliga loopar stoppas loopen även om något av följande villkor inträffar:
- Loopen kördes 10 gånger enligt attributet - count. Standardvärdet är 60 gånger.
- Loopen kördes i två timmar enligt - timeoutattributet i ISO 8601-format. Standardvärdet är en timme.
"actions": {
   "myUntilLoopName": {
      "type": "Until",
      "actions": {
         "Create_new_resource": {
            "type": "Http",
            "inputs": {
               "body": {
                  "resourceId": "@triggerBody()"
               },
               "url": "https://domain.com/provisionResource/create-resource"
            },
            "runAfter": {},
            "type": "ApiConnection"
         }
      },
      "expression": "@equals(body('Create_new_resource'), 'Completed')",
      "limit": {
         "count": 10,
         "timeout": "PT2H"
      },
      "runAfter": {}
   }
}
 
              
               
              
               
              
               
              
              