- Versionshinweise
- Erste Schritte
- Einstellung und Konfiguration (Setup and Configuration)
- Automationsprojekte
- Abhängigkeiten
- Workflow-Typen
- Dateivergleich
- Beste Praktiken für die Automatisierung (Automation Best Practices)
- Integration der Quellenkontrolle
- Debugging
- Das Diagnose-Tool
- Workflow-Analyse
- Über die Workflow-Analyse
- ST-NMG-001 – Namenskonvention für Variablen
- ST-NMG-002 – Namenskonvention für Argumente
- ST-NMG-004 – Duplizierung des Anzeigenamens
- ST-NMG-005 – Variable überschreibt Variable
- ST-NMG-006 – Variable überschreibt Argument
- ST-NMG-008 – Variablenlänge überschritten
- ST-NMG-009: Datentabellenvariablen mit Präfix versehen
- ST-NMG-011 – Datentabellenargumente mit Präfix versehen
- ST-NMG-012 – Standardwerte für Argumente
- ST-NMG-016 – Argumentlänge überschritten
- ST-DBP-002 – Hohe Anzahl von Argumenten
- ST-DBP-003 – Leerer Catch-Block
- ST-DBP-007 – Mehrere Flussdiagrammebenen
- ST-DBP-020 – Nicht definierte Ausgabeeigenschaften
- ST-DBP-023 – Leerer Workflow
- ST-DBP-024 – Prüfung der Persistenzaktivität
- ST-DBP-025 – Voraussetzung für Variablenserialisierung
- ST-DBP-026 – Verwendung der Verzögerungsaktivität
- ST-DBP-027 – Bewährte Methode für Persistenz
- ST-DBP-028 – Voraussetzung für Argumentenserialisierung
- ST-USG-005 – Hartcodierte Aktivitätsargumente
- ST-USG-009 – Nicht verwendete Variablen
- ST-USG-010 – Nicht verwendete Abhängigkeiten
- ST-USG-014 – Paketbeschränkungen
- ST-USG-020 – Minimale Protokollmeldungen
- ST-USG-024 – Nicht verwendet, gespeichert für später
- ST-USG-025 – Missbrauch gespeicherter Werte
- ST-USG-026 – Aktivitätseinschränkungen
- ST-USG-027 – Erforderliche Pakete
- ST-USG-028 – Aufruf von Dateivorlagen einschränken
- Variablen
- Verwalten von Variablen
- Das Variablen-Panel
- Proprietäre UiPath-Variablen
- Argumente
- Importierte Namespaces
- Aufzeichnung
- UI-Elemente
- Kontrollfluss
- Selektoren
- Objekt-Repository
- Data-Scraping
- Bild- und Textautomatisierung
- Automatisierung von Citrix-Technologien
- RDP-Automatisierung
- Salesforce-Automatisierung
- SAP-Automation
- VMware Horizon-Automatisierung
- Protokollierung
- Das Tool ScreenScrapeJavaSupport
- Das WebDriver-Protokoll
- Test Suite – Studio
- Erweiterungen
- Fehlersuche und ‑behebung
- Informationen zur Fehlerbehebung
- Microsoft App-V – Unterstützung und Einschränkungen
- Fehlerbehebung bei Internet Explorer x64
- Probleme in Microsoft Office
- Erkennen von UI-Elementen in PDF mit Zugriffsoptionen.
- Reparieren der Active Accessibility-Unterstützung
- Fehlerbehebung bei JxBrowser-Anwendungen
- Überwachung der Benutzerereignisse (User Events Monitoring)
- Citrix-Fehlerbehebung
- Automatisieren von Anwendungen, die unter einem anderen Windows-Benutzer ausgeführt werden
Proprietäre UiPath-Variablen
Die GenericValue-Variable ist ein Studio-spezifischer Variablentyp, in dem beliebige Daten, einschließlich Text, Zahlen, Datumsangaben und Arrays gespeichert werden können.
GenericValue-Variablen werden automatisch in andere Typen konvertiert, um bestimmte Aktionen auszuführen. Es ist jedoch wichtig, diese Variablentypen sorgfältig zu verwenden, da ihre Konvertierung möglicherweise nicht immer für Ihr Projekt geeignet ist.
UiPath Studio verfügt über einen automatischen Konvertierungsmechanismus für GenericValue-Variablen, der Sie durch sorgfältiges Definieren ihrer Ausdrücke zum gewünschten Ergebnis führen kann. Berücksichtigen Sie, dass das erste Element in Ihrem Ausdruck als Richtlinie für die von Studio durchgeführte Operation verwendet wird. Wenn Sie beispielsweise versuchen, zwei GenericValue-Variablen hinzuzufügen, ist das Ergebnis, wenn die erste im Ausdruck als String definiert ist, die Verkettung der beiden. Wenn sie als Integer definiert ist, ist das Ergebnis ihre Summe.
Name/Syntax |
Beschreibung |
---|---|
CompareTo
|
[Klicken Sie hier für Details.][1] [1]: https://msdn.microsoft.com/en-us/library/system.string.compareto(v=vs.110).aspx |
Enthält
|
[Klicken Sie hier für Details.][2] [2]: https://msdn.microsoft.com/en-us/library/dy85x1sa(v=vs.110).aspx Wird verwendet, um zu überprüfen, ob eine String-Variable einen bestimmten Teilstring enthält oder nicht. Wenn Sie beispielsweise prüfen möchten, ob ein Satz ein bestimmtes Wort enthält, sollte der Ausdruck
[SentenceVariable].Contains("term") lauten, wobei [SentenceVariable] die GenericValue-Variable ist, die den Satz enthält, und "term" das Wort, nach dem gesucht werden soll.
Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Equals
|
[Klicken Sie hier für Details.][3] [3]: https://msdn.microsoft.com/en-us/library/system.string.equals(v=vs.110).aspx |
GetHashCode
|
[Klicken Sie hier für Details.][5] [5]: https://msdn.microsoft.com/en-us/library/system.string.format(v=vs.110).aspx |
GetType
|
[Klicken Sie hier für Details.][6] [6]: https://msdn.microsoft.com/en-us/library/system.object.gettype(v=vs.110).aspx |
GetTypeCode
|
[Klicken Sie hier für Details.][7] [7]: https://msdn.microsoft.com/en-us/library/system.string.gettypecode(v=vs.110).aspx |
IndexOf
|
[Klicken Sie hier für Details.][8] [8]: https://msdn.microsoft.com/en-us/library/system.string.indexof(v=vs.110).aspx Wird verwendet, um den Index einer Teilzeichenfolge zurückzugeben, die in einer Zeichenfolgenvariablen enthalten ist. Wenn Sie beispielsweise den Index des Worts „suchen“ innerhalb des Satzes „In diesem Satz 'suchen' finden“ finden möchten, sollte der Ausdruck
[SentenceVariable].IndexOf("locate") sein, wobei [SentenceVariable] die GenericValue-Variable ist, die den Satz enthält, und "locate" der Begriff ist, nach dem gesucht werden soll.
Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Länge
|
[Klicken Sie hier für Details.][9] [9]: https://msdn.microsoft.com/en-us/library/system.string.length(v=vs.110).aspx Wird verwendet, um die Anzahl der Zeichen in einer String-Variable zurückzugeben. Wenn Sie beispielsweise herausfinden möchten, wie viele Buchstaben ein Wort hat, sollte der Ausdruck
[WordVariable].Length lauten, wobei [WordVariable] die GenericValue-Variable ist, die das Wort enthält.
Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Ersetzen (Replace)
|
[Klicken Sie hier für Details.][10] [10]: https://msdn.microsoft.com/en-us/library/system.string.replace(v=vs.110).aspx Wird verwendet, um Daten in einer String-Variable zu ersetzen. Wenn Sie beispielsweise einen lokalen Dateipfad
C:\ExampleFolder\Main.xaml in den entsprechenden Serverdateipfad C:/ExampleFolder/Main.xaml ändern möchten, sollte der Ausdruck [PathVariable].Replace("\","/") lauten, wobei [PathVariable] die GenericValue-Variable mit dem Dateipfad ist, "\" das zu ersetzende Zeichen und "/" das stattdessen zu verwendende Zeichen.
Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Teilen
|
[Klicken Sie hier für Details.][11] [11]: https://msdn.microsoft.com/en-us/library/system.string.split(v=vs.110).aspx Wird verwendet, um einzelne Komponenten aus einer String-Variable zurückzugeben. Wenn Sie beispielsweise das Jahr aus einem Datumsformat MM.TT.JJJJ extrahieren möchten, sollte der Ausdruck
[DateVariable].Split(".".ToCharArray)(2) lauten, wobei [DateVariable] die GenericValue-Variable ist, die das Datum enthält, "." das Zeichen, das als Trennzeichen verwendet wird, .ToCharArray eine Methode, die einen Array mit den durch das Trennzeichen begrenzten Elementen erstellt und (2) der Index des Elements, das zurückgegeben werden soll, in unserem Fall das Jahr.
Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Substring
|
[Klicken Sie hier für Details.][12] [12]: https://msdn.microsoft.com/en-us/library/system.string.substring(v=vs.110).aspx Wird verwendet, um eine Teilzeichenfolge zurückzugeben, die in einer Zeichenfolgenvariablen enthalten ist. Wenn Sie z. B. ein Wort aus dem Satz „Es sind 100 Maschinen verfügbar“ extrahieren möchten, sollte der Ausdruck
[SentenceVariable].Substring(10,3) sein, wobei [SentenceVariable] die GenericValue-Variable ist, die den Satz enthält, 10 der Index des ersten zurückzugebenden Zeichens und 3 die Länge der Teilzeichenfolge ab dem ersten Zeichen ist. In diesem Beispiel wäre die resultierende Teilzeichenfolge „100“.
Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
ToBoolean
|
[Klicken Sie hier für Details.][13] [13]: https://msdn.microsoft.com/en-us/library/bb346937(v=vs.110).aspx |
ToByte
|
[Klicken Sie hier für Details.][14] [14]: https://msdn.microsoft.com/en-us/library/bb355898(v=vs.110).aspx |
ToChar
|
[Klicken Sie hier für Details.][15] [1]: https://msdn.microsoft.com/en-us/library/t249c2y7(v=vs.110).aspx |
ToDecimal
|
[Klicken Sie hier für Details.][17] [17]: https://msdn.microsoft.com/en-us/library/bb359959(v=vs.110).aspx |
ToDouble
|
[Klicken Sie hier für Details.][18] [18]: https://msdn.microsoft.com/en-us/library/bb154906(v=vs.110).aspx |
ToInt
|
Wird verwendet, um einen angegebenen Wert in einen Integer-Wert zu konvertieren, der einen Nullwert zulässt. Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToInt16
|
[Klicken Sie hier für Details.][20] [20]: https://msdn.microsoft.com/en-us/library/bb293091(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToInt32
|
[Klicken Sie hier für Details.][21] [21]: https://msdn.microsoft.com/en-us/library/bb300452(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToInt64
|
[Klicken Sie hier für Details.][22] [22]: https://msdn.microsoft.com/en-us/library/bb359566(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToLower
|
[Klicken Sie hier für Details.][23] [23]: https://msdn.microsoft.com/en-us/library/system.string.tolower(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
ToLowerInvariant
|
[Klicken Sie hier für Details.][24] [24]: https://msdn.microsoft.com/en-us/library/system.string.tolowerinvariant(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
ToSByte
|
[Klicken Sie hier für Details.][25] [25]: https://msdn.microsoft.com/en-us/library/bb342232(v=vs.110).aspx |
ToSingle
|
[Klicken Sie hier für Details.][26] [26]: https://msdn.microsoft.com/en-us/library/bb360375(v=vs.110).aspx |
In Zeichenfolge umwandeln
|
[Klicken Sie hier für Details.][27] [27]: https://msdn.microsoft.com/en-us/library/system.string.tostring(v=vs.110).aspx |
ToType
|
[Klicken Sie hier für Details.][29] [29]: https://msdn.microsoft.com/en-us/library/bb358540(v=vs.110).aspx |
ToUInt16
|
[Klicken Sie hier für Details.][30] [30]: https://msdn.microsoft.com/en-us/library/bb337265(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToUInt32
|
[Klicken Sie hier für Details.][31] [31]: https://msdn.microsoft.com/en-us/library/bb357762(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToUInt64
|
[Klicken Sie hier für Details.][32] [32]: https://msdn.microsoft.com/en-us/library/bb155099(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Boolean verwenden, werden die Werte „True“ und „False“ in 1 bzw. 0 konvertiert.
|
ToUpper
|
[Klicken Sie hier für Details.][33] [33]: https://msdn.microsoft.com/de-de/library/system.string.toupper(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
ToUpperInvariant
|
[Klicken Sie hier für Details.][34] [34]: https://msdn.microsoft.com/en-us/library/system.string.toupperinvariant(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Trim
|
[Klicken Sie hier für Details.][35] [35]: https://msdn.microsoft.com/en-us/library/system.string.trim(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
TrimEnd
|
[Klicken Sie hier für Details.][36] [36]: https://msdn.microsoft.com/en-us/library/system.string.trimend(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
TrimStart
|
[Klicken Sie hier für Details.][37] [37]: https://msdn.microsoft.com/en-us/library/system.string.trimstart(v=vs.110).aspx Hinweis: Wenn Sie diese Methode mit einer GenericValue-Variable vom Datentyp Int, Float oder Boolean verwenden, werden die Daten automatisch in einen String konvertiert, der entsprechend behandelt wird.
|
Wenn Sie Strg + K, Strg + M oder Strg + Umschalt + M direkt im Aktivitätstext Formatwert verwenden, ist die erstellte Variable oder das Argument vom Typ GenericValue. Bei anderen Aktivitäten entspricht der erstellte Typ dem erforderlichen Typ der Aktivität.
Um zu veranschaulichen, wie eine GenericValue-Variable funktioniert, erstellen wir eine Automatisierung, die verschiedene Vorgänge ausführt, deren Ergebnisse davon abhängen, wie wir ihre Ausdrücke definieren. Wir erstellen zwei GenericValue-Variablen mit unterschiedlichen Datentypen und zeigen die Ergebnisse im Panel Ausgabe (Output) an.
- Erstellen Sie ein neues leeres Projekt.
- Erstellen Sie drei GenericValue-Variablen:
Int
,Str
undResult
. -
Geben Sie den Wert 12 für die Variable
Int
in der Spalte Standard (Default) ein und für die VariableStr
den Wert "34". Die erste Variable wird als Integer, die zweite als String interpretiert. - Fügen Sie eine Zuweisen (Assign)-Aktivität in das Panel Designer (Designer) ein und verbinden Sie sie mit dem Knoten Start.
- Geben Sie die Variable
Result
im Panel Eigenschaften (Properties) in das Feld An (To) ein. - Geben Sie
Int
+Str
in das Feld Wert (Value) ein. - Fügen Sie eine Zeile schreiben (Write Line)-Aktivität hinzu und verbinden Sie diese mit der Aktivität Zuweisen (Assign).
-
Geben Sie die Variable
Result
im Panel Eigenschaften im Feld Text ein.Das finale Projekt sollte wie auf dem folgenden Screenshot aussehen.
-
Drücken Sie F5, um Ihre Automatisierung auszuführen. Beachten Sie, dass im Panel Ausgabe (Output) die Summe der beiden Zahlen angezeigt wird.
-
Gehen Sie zur zuvor hinzugefügten Zuweisen (Assign)-Aktivität zurück und ändern Sie das Feld Wert (Value) in
Str
+Int
, um die Reihenfolge der Variablen umzukehren. Das finale Projekt sollte wie auf dem folgenden Screenshot aussehen. -
Drücken Sie F5, um Ihre Automatisierung auszuführen. Beachten Sie, dass im Panel Ausgabe (Output) die Verkettung der beiden Zahlen angezeigt wird.
Das bedeutet, dass UiPath Studio das erste in Ihrem Ausdruck definierte Element als Richtlinie für die auszuführende Operation verwendet. Wenn das erste Element in Ihrem Ausdruck eine Integer- oder GenericValue-Variable ist, die als Integer eingegeben ist, addiert UiPath Studio die Elemente.
Wenn das erste Element in Ihrem Ausdruck ein String oder eine GenericValue-Variable ist, die als String eingegeben ist, verkettet UiPath Studio die Elemente.
Wir empfehlen Ihnen, die Seite Über Warteschlangen und Transaktionen (About Queues and Transactions) zu lesen, die eine Übersicht der Warteschlangen und Transaktionen enthält, bevor Sie mit der Variablen Warteschlangenobjekt fortfahren.
Bevor Sie sich tiefer in die Details des Themas einarbeiten, sollten Sie den Unterschied zwischen Warteschlangenobjekten (Objekten, die in Orchestrator in einer Warteschlange gespeichert sind) und Warteschlangenobjekt-Variablen (Variablen, mit denen in Studio Warteschlangenobjekte bearbeitet werden) verstanden haben. Wir bezeichnen sie genau folgendermaßen: „Warteschlangenobjekt-Variablen“ und „Warteschlangenobjekte“.
Generell speichert die Warteschlangenobjekt-Variable, wie schon der Name besagt, ein Objekt, das aus einem Objekt-Container, einer Warteschlange, extrahiert wurde. Diese Extraktion wird generell zu dem Zweck durchgeführt, diese Warteschlangenobjekte in verschiedenen Szenarien weiterzuverwenden. Sagen wir, Sie repräsentieren eine Bank und haben Einlagen von 50 Kunden. Sie möchten die Daten jedes Kunden bearbeiten, der zuvor einen auf uns bezogenen Scheck von weniger als $ 5000 mit einer Fremdfinanzanwendung eingezahlt hat. Dazu können Sie einen Workflow erstellen, bei dem in der Warteschlangenobjekt-Variablen jeweils die Daten eines Kunden gespeichert sind. Jeder von der Warteschlangenobjekt-Variablen gelesene Eintrag wird in einem Warteschlangenobjekt gespeichert und in Orchestrator zur angegebenen Warteschlange hinzugefügt. Als Ergebnis dieses Prozesses entsteht eine Warteschlange, welche die Kundendaten im entsprechenden Warteschlangenobjekt enthält.
Zur weiteren Bearbeitung der Daten, welche die Bedingung erfüllen, müssen Sie einen weiteren Workflow erstellen, welcher aus der zuvor erstellten Warteschlange diejenigen Objekte extrahiert, die einen entsprechenden auf uns bezogenen Scheckwert von unter $ 5000 aufweisen. Am Ende dieses Kapitels können Sie lesen, wie man ein derartiges Projekt erstellt.
Name/Syntax |
Beschreibung |
---|---|
Equals
| |
GetHashCode
| |
GetType
| |
In Zeichenfolge umwandeln
|
Name/Syntax |
Beschreibung |
---|---|
Zugewiesen zu (AssignedTo)
| |
Fälligkeitsdatum (DueDate)
|
Das aktuellste Datum mit Uhrzeit, an dem das Objekt verarbeitet werden soll. Ist das Objekt leer, kann es jederzeit bearbeitet werden. |
Verschiebungsdatum (DeferDate)
|
Das aktuellste Datum mit Uhrzeit, an dem das Objekt zur Verarbeitung zur Verfügung steht. Ist das Objekt leer, kann es baldmöglichst bearbeitet werden. |
ID
| |
Objektschlüssel (ItemKey)
|
Der einmalige Identifier des Objekts. Zum Beispiel
1bf829e1-cd6b-4275-a364-19db3cfe09c7 .
|
Priorität
|
Die Priorität des Warteschlangenobjekts, die bei Studio im Feld Priorität (Priority) im Abschnitt Eigenschaften (Properties) festgelegt wurde. |
Verarbeitungsausnahme (ProcessingException)
|
Die Verarbeitungsausnahme eines fehlgeschlagenen Objekts. |
Fortschritt
|
Benutzerdefinierte Fortschrittsinformationen über ein Warteschlangenobjekt mit dem Status (In Bearbeitung (InProgress). |
ID Warteschlangendefinition (QueueDefinitionId)
|
Der einmalige Identifier der Warteschlange, unter dem ein Warteschlangenobjekt/eine Transaktion erstellt wurde. |
Warteschlangenname (QueueName)
|
Der Name der Warteschlange, welche die bearbeiteten Objekte enthält. |
Referenz (Reference)
|
Ein benutzerdefinierter Wert zur einfacheren Erkennung des Warteschlangenobjekts. |
Anzahl Wiederholungen (RetryNo)
|
Wie oft das Objekt wiederholt wurde. |
Status überprüfen (Review Status)
|
Der Überprüfungsstatus des von Orchestrator abgerufenen Warteschlangenobjekts. |
RowVersion
|
Ein internes Feld, das für den Versionsstempel verwendet wird. Es wird immer dann aktualisiert, wenn eine Eigenschaft der aktuellen Transaktion geändert wird. |
Spezieller Inhalt (SpecificContent)
|
Eine Gruppe von Schlüsselwertepaaren mit benutzerdefinierten zur aktuellen Transaktion gehörenden Daten, wie in der Aktivität Warteschlangenobjekt hinzufügen (Add Queue Item) konfiguriert. |
Start Transaktionszeit (StartTransactionTime)
|
Uhrzeit und Datum des Beginns der Transaktionsverarbeitung. |
Status
|
Der Status des von Orchestrator abgerufenen Warteschlangenobjekts. |
Aufgrund der Eigenart dieses Beispiels haben wir diesen Abschnitt in zwei Teile aufgespalten, die jeweils einen der beiden Haupt-Workflows darstellen, die beim Arbeiten mit Warteschlangen und Warteschlangenobjekten verwendet werden müssen.
Hinzufügen von Objekten zu einer Warteschlange
.xlsx
enthaltene Einträge verarbeitet. Sagen wir, Sie repräsentieren eine Bank und haben Einlagen von 50 Kunden. Sie möchten die Daten jedes Kunden bearbeiten, der zuvor einen auf uns bezogenen Scheck von weniger als $ 5000 mit einer Fremdfinanzanwendung eingezahlt hat. Der Bericht enthält den Namen des Kunden, den Wert des auf uns bezogenen Schecks und zwei weitere Werte, etwa Einzahlung und Nicht auf uns bezogener Scheck. Wir erstellen einen Workflow, bei dem in der Warteschlangenobjekt-Variablen jeweils die Daten jedes Kunden gespeichert sind. Jeder von der Variablen Warteschlangenobjekt gelesene Eintrag wird in einem Warteschlangenobjekt gespeichert und in Orchestrator zur angegebenen Warteschlange hinzugefügt. Als Ergebnis dieses Prozesses entsteht eine Warteschlange, welche die speziellen Informationen jedes Kunden enthält. Bevor wir mit dem eigentlichen Workflow fortfahren, sollten Sie sich den Kundenbericht hier ansehen. Wir arbeiten mit dem Arbeitsblatt „Juliberichte“.
Ohne weitere Umstände:
- Erstellen Sie eine neue Sequence.
- Fügen Sie eine Excel Application Scope-Aktivität in die Sequence ein, und definieren Sie die Position der Arbeitsmappe im Abschnitt Eigenschaften der Aktivität.
- Fügen Sie im Abschnitt Ausführen eine Read Range -Aktivität ein, um den gewünschten Wertebereich des Berichts zu lesen und die Werte in einer DataTable -Variablen zu speichern. Geben Sie in unserem Fall
"A1-D51"
ein oder lassen Sie einfach den Standardwert “” stehen, um anzugeben, dass die gesamte Kalkulationstabelle gelesen wird. - Geben Sie in das Feld Blattname den Namen des Blatts ein,
“July Report”
. -
Drücken Sie im Feld Datentabelle (Data Table) Strg + K, um eine neue Datentabellen-Variable zu erstellen, in welcher der zuvor gelesene Datenbereich gespeichert wird. Nennen Sie sie
DataTable1
oder ähnlich. Im Variablen-Bereich sollte die neu erstellte Variable auch wie folgt angezeigt werden: -
Dann fügen Sie eine Aktivität Für jede Zeile zum Panel Designer hinzu und tragen in die leeren Felder „Zeile“ und den Namen der Datentabellen-Variablen,
DataTable1
, ein. Diese Aktivität führt die im Abschnitt Textkörper für jede Zeile der Datentabelle angegebene Aktion aus. Der Abschnitt Ausführen sollte jetzt wie auf dem folgenden Screenshot aussehen: - Fügen Sie im Abschnitt Textkörper (Body) der Aktivität Für jede Zeile (For Each Row) eine Aktivität Warteschlangenobjekt hinzufügen (Add Queue Item) hinzu. Damit wird für jede Zeile im Arbeitsblatt ein Objekt zu einer (in Schritt 8 und 12 unten definierten) Warteschlange hinzugefügt.
- Geben Sie im Abschnitt Eigenschaften im Feld QueueName den Namen der Warteschlange ein, in der Sie die Elemente speichern möchten, zum Beispiel
ReportQueue
. -
Klicken Sie im Abschnitt Eingabe (Input) auf die Schaltfläche, die dem Feld Objektinformationen (ItemInformation) entspricht, um das Fenster Objektinformationen (ItemInformation) zu öffnen. Erstellen Sie 4 Argumente, die jeweils einer Berichtsspalte entsprechen. Definieren Sie diese folgendermaßen:
Name
, behält die Standardwerte für Richtung (Direction) und Typ (Typ), wobei Wert (Value) aufrow(0).ToString
festgelegt ist. Damit wird der Wert aus der Spalte mit dem Zähler 0 für jede Zeile des Arbeitsbuches abgerufen. In unserem Fall ist dies der Name des Kunden.CashIn
, behält die Standardwerte für Richtung (Direction) und Typ (Typ), wobei Wert (Value) aufrow(1).ToString
festgelegt ist. Damit wird der Wert aus der Spalte mit dem Zähler 1 für jede Zeile des Arbeitsbuches abgerufen. In unserem Fall ist dies der Einzahlungswert (Cash In).OnUsCheck
, behält die Standardwerte für Richtung (Direction) und Typ (Typ), wobei Wert (Value) aufrow(2).ToString
festgelegt ist. Damit wird der Wert aus der Spalte mit dem Zähler 2 für jede Zeile des Arbeitsbuches abgerufen. In unserem Fall ist dies der Wert des auf uns bezogenen Schecks (On-Us Check).NotOnUsCheck
, behält die Standardwerte für Richtung (Direction) und Typ (Typ), wobei Wert (Value) aufrow(3).ToString
festgelegt ist. Damit wird der Wert aus der Spalte mit dem Zähler 3 für jede Zeile des Arbeitsbuches abgerufen. In unserem Fall ist dies der Wert des Nicht auf uns bezogenen Schecks (Not On-Us Check).
-
Das Fenster Objektinformationen (ItemInformation) sollte ähnlich dem folgenden Screenshot aussehen:
- Verbinden Sie den Studio-Roboter mit Orchestrator. Die Vorgehensweise ist hier beschrieben.
- Navigieren Sie zu https://cloud.uipath.com, melden Sie sich mit Ihren Anmeldeinformationen an und anschließend erstellen Sie eine Warteschlange, „ReportQueue“, um die Elemente zu speichern. Stellen Sie sicher, dass Sie hier den gleichen Namen wie zuvor in Schritt 8 verwenden.
- Gehen Sie zurück zu Studio. Bis dahin sollte Ihr Workflow fehlerfrei und funktionstüchtig sein. Im nächsten Schritt müssen Sie ihn für Orchestrator zur Verfügung stellen. Klicken Sie in dieser Hinsicht auf Design (Design) > Veröffentlichen (Publish).
-
Klicken Sie auf Design (Design) > Ausführen (Run), um den Prozess auszuführen.
Hinweis: TBerücksichtigen Sie, dass Warteschlangenobjekte nach Bearbeitung zu Transaktionen werden und als solche zu behandeln sind. - Navigieren Sie wieder zu https://paltform.uipath.com und zeigen Sie die Transaktionen an.
Bearbeiten der Transaktionen aus einer Warteschlange
Um zu veranschaulichen, wie Transaktionen aus einer Warteschlange weiterbearbeitet werden, erstellen wir einen weiteren Workflow, welcher aus der zuvor erstellten Warteschlange diejenigen Transaktionen abruft, die einen entsprechenden auf uns bezogenen Scheckwert von unter $ 5000 aufweisen. Für jede Transaktion, welche die Bedingung erfüllt, werden die Werte abgerufen und in eine Drittparteien-Dummy-Anwendung eingefügt. Die restlichen werden als Geschäftsausnahmen beschriftet.
- Gehen Sie zu Design (Design) > Neu (New) > Flowchart, um eine neue Datei im oben begonnenen Projekt zu erstellen.
- Fügen Sie eine Open Application-Aktivität hinzu, um die Dummy-Anwendung eines Drittanbieters zu öffnen. Verbinden Sie diese mit dem Knoten Start.
- Geben Sie die erforderlichen Details (Anzeigename, Dateipfad, Selektor) im Eigenschaften-Bereich ein und konfigurieren Sie die Aktivität, um sich mit den entsprechenden Anmeldeinformationen anzumelden. Verwenden Sie
admin
für das Feld Benutzername undpassword
für das Feld Kennwort. - Tragen Sie im Feld Dateiname (FileName) den Pfad der Anwendung ein.
- Definieren Sie im Feld Selektor (Selector) mit dem Selektor Editor einen Selektor für UIDemo.
- Fügen Sie eine Sollte anhalten (Should Stop)-Aktivität in das Panel Designer (Designer) ein und verbinden Sie diese mit der Aktivität Anwendung öffnen (Open Application).
-
Fügen Sie eine Ablaufentscheidung (Flow Decision)-Aktivität in das Panel Designer (Designer) ein und verbinden Sie diese mit der Aktivität Sollte anhalten (Should Stop). Diese beiden letzten Aktivitäten prüfen, ob Sie den Job angehalten haben, während er noch ausgeführt wurde. Dies gibt Ihnen die Möglichkeit, den Workflow weiter zu konfigurieren, um verschiedene Sicherheitsroutinen auszuführen, nachdem das Anhalten ausgelöst wurde. Nachfolgend sehen Sie ein Beispiel für solch eine Routine:
- Fügen Sie eine Log Message-Aktivität hinzu, und verbinden Sie diese mit der Verzweigung True der zuvor hinzugefügten Ablaufentscheidung.
- Geben Sie im Bereich Eigenschaften (Properties) im Feld Meldung (Message) „Prozess anhalten erforderlich“ oder Ähnliches ein, das angezeigt wird, wenn Anhalten ausgelöst wird.
- Fügen Sie eine Close Application-Aktivität hinzu, und verbinden Sie diese mit der zuvor hinzugefügten Aktivität Log Message.
- Geben Sie im Panel Eigenschaften (Properties) im Feld Anzeigename (DisplayName) hinter Anwendung schließen (Close Application)
UIDemo.exe UIDemo
ein.
- Fügen Sie eine Get Transaction Item-Aktivität zur Verzweigung False der zuvor hinzugefügten Ablaufentscheidung (Schritt 7) hinzu. Diese Aktivität ruft die Transaktionsobjekte aus der Warteschlange ab und speichert sie bei jeder Iteration der Schleife in einer QueueItem-Variablen.
- Geben Sie im Abschnitt Eigenschaften (Properties) im Feld Name der Warteschlange (QueueName) den Namen der Warteschlange ein, in der die Objekte gespeichert werden. In unserem Fall lautet der Name „ReportQueue“, wie im Abschnitt Objekte in eine Warteschlange hochladen (Uploading Items into a Queue) festgelegt.
- Drücken Sie im Feld TransactionItem Strg+K, um die QueueItem-Variable zu erstellen, in welcher jedes Transaktionsobjekt gespeichert wird. Nennen Sie sie „TransItem“ oder ähnlich.
- Fügen Sie eine Flow Decision-Aktivität in das Panel Designer ein, und verbinden Sie diese mit der Aktivität Get Transaction Item.
- Geben Sie im Abschnitt Eigenschaften
TransItem isNot Nothing
in das Feld Bedingung ein. Diese Aktivität prüft den Wert jedes Elements, um festzustellen, ob das Ende der Warteschlange erreicht ist. - Verbinden Sie die Verzweigung False der Ablaufentscheidung mit der in Schritt 7 erstellten Aktivität Log Message. Dadurch wird sichergestellt, dass der Auftrag angehalten wird, wenn das Ende der Warteschlange erreicht ist.
- Fügen Sie dem Panel Designer eine weitere Flow Decision-Aktivität hinzu, und verbinden Sie sie mit der in Schritt 11 erstellten Verzweigung True der Ablaufentscheidung.
-
Geben Sie im Abschnitt Eigenschaften (Properties) in das Feld Bedingung (Condition)
cint(TransItem.SpecificContent("OnUSCheck").ToString) < 5000
ein, wobei:cint
eine Variable des Typs String in eine vom Typ „Integer“ konvertiert.TransItem
Ist die QueueItem-Variable (Schritt 18), die zum Speichern der Elemente dient.SpecificContent("OnUSCheck")
den Inhalt des Arguments des auf UNS bezogenen Schecks in jedem Objekt abruft..ToString
den Inhalt der Warteschlangenobjekt-Variablen in eine Variable vom Typ „String“ konvertiert.-
< 5000
ist die Bedingung, gegen die geprüft werden soll.Der obige Ausdruck konvertiert den Wert des auf UNS bezogenen Schecks in jeder Warteschlangenobjekt-Variablen in eine String-Variable, die dann weiter in eine „Integer“ konvertiert wird. Der so erhaltene Wert wird auf Übereinstimmung mit der Bedingung geprüft.
- Fügen Sie eine Aktivität Transaktionsstatus festlegen zum Panel Designer hinzu und verbinden Sie diese mit der Verzweigung False der vorherigen Ablaufentscheidung (Schritt 13).
- Achten Sie darauf, dass im Abschnitt Eigenschaften (Properties) das Feld Status (Status) auf Fehlgeschlagen (Failed) und der Fehlertyp (ErrorType) auf Geschäft (Business) festgelegt ist. Auf diese Weise wird die Transaktion als fehlgeschlagen mit einer Geschäftsausnahme markiert, wenn der Wert des auf UNS bezogenen Schecks größer oder gleich 5000 lautet.
- Fügen Sie die Variable
TransItem
in das Feld Transaktionselement (TransactionItem) ein. - Geben Sie im Feld Grund (Reason) „Auf UNS bezogener Scheckbetrag ist höher als 5000“ oder Ähnliches ein, um anzuzeigen, dass die Transaktion fehlgeschlagen ist.
- Verbinden Sie die Transaktionsstatus festlegen (Set Transaction Status)-Aktivität mit der Aktivität Sollte anhalten (Should Stop) (Schritt 6), um eine Schleife zu erstellen und die nächste Transaktion in der Warteschlange zu bearbeiten.
- Fügen Sie eine Sequence-Aktivität zum Panel Designer, und verbinden Sie diese mit der Verzweigung True der vorherigen Ablaufentscheidung (Schritt 13). Fügen Sie in der Sequence eine Try Catch-Aktivität hinzu, und konfigurieren Sie diese so, dass potenzielle Fehler beim Bearbeiten der Elemente korrekt als Anwendungsfehler gekennzeichnet werden.
- Öffnen Sie die UIDemo-Anwendung und melden Sie sich mit dem Benutzernamen
admin
und dem Passwortpassword
an. -
Führen Sie die folgende Serie von Aktivitäten für jedes der Felder Einzahlung (Cash In), Auf uns bezogener Scheck (On Us Check) und Nicht auf uns bezogener Scheck (Not On Us Check) in der UIDemo-Anwendung durch:
- Fügen Sie in die vorherige Aktivität Abfangen versuchen (Try Catch) eine Aktivität Eingabe in (Type Into) ein.
- Klicken Sie auf Auf dem Bildschirm anzeigen (Indicate on screen) und wählen Sie aus der UIDemo-Bedienoberfläche das leere Feld aus, das „Einzahlung“ entspricht.
- Geben Sie im Abschnitt Eigenschaften
transItem.SpecificContent("CashIn").ToString
in das Feld Text ein. Jeder Begriff im Ausdruck wird oben erläutert (Schritt 15). Dieser Ausdruck wandelt den Wert in jeder „QueueItem“-Variablen in eine String-Variable um. - Stellen Sie sicher, dass die Option Eingabe simulieren (Simulate Type) ausgewählt ist.
-
Klicken Sie auf der Registerkarte Design (Design) im Abschnitt Assistenten (Wizards) auf Bildschirm-Scraping (Screen Scraping) und zeigen Sie auf die Transaktionsnummer in der UIDemo-Anwendung.
- Wählen Sie im Bildschirm-Scraper-Assistenten (Screen Scraper Wizard) eine Scraping-Methode aus und klicken Sie auf Fertigstellen (Finish). Dadurch wird in Ihren Workflow eine Aktivität Bildschirm-Scraping (Screen Scraping) eingefügt. Achten Sie darauf, diese hinter die vorherigen Aktivitäten Eingabe in (Type Into) zu stellen, und geben Sie eine neue Variable, zum Beispiel
TransactionValue
, im Feld Text (Text) an. Dadurch wird die Transaktionsnummer für jedes Warteschlangenelement abgerufen, das die ursprüngliche Bedingung erfüllt. - Fügen Sie eine Aktivität Transaktionsstatus festlegen (Set Transaction Status) hinter der Aktivität Bildschirm-Scraping (Screen Scraping) hinzu.
- Achten Sie darauf, dass im Abschnitt Eigenschaften (Properties) das Feld Status (Status) auf Erfolgreich (Successful) und der Fehlertyp (ErrorType) auf Anwendung (Application) gesetzt ist. So wird der Transktionsstatus auf Erfolgreich (Successful) gesetzt, wenn der Wertesatz erfolgreich in die Anwendung aufgenommen wurde, oder als Anwendungsausnahme beschriftet.
- Definieren Sie im Fenster Ausgabe ein neues Argument, und fügen Sie die zuvor erstellte Variable
TransactionValue
(Schritt 25) als Wert hinzu. - Fügen Sie die Variable
TransItem
in das Feld Transaktionselement (TransactionItem) ein. - Fügen Sie eine Klicken- (Click)Aktivität zur Sequence-Aktivität hinter den Aktivitäten Eingeben (Type Into) hinzu.
- Klicken Sie auf Auf dem Bildschirm anzeigen (Indicate on screen) und wählen Sie die Schaltfläche Akzeptieren (Accept) der UIDemo-Bedienoberfläche aus. Stellen Sie sicher, dass die Option Typ simulieren (Simulate Type) ausgewählt ist.
-
Die Try Catch-Aktivität sollte wie auf dem folgenden Screenshot aussehen.
- Gehen Sie zurück zum Flowchart, und verbinden Sie die vorherige Sequence-Aktivität (Schritt 21) mit der Aktivität Should Stop (Schritt 6), um eine Schleife zu erstellen und die nächste Transaktion in der Warteschlange zu bearbeiten.
-
Das Flowchart sollte wie auf dem folgenden Screenshot aussehen.
- Klicken Sie auf Design (Design) > Ausführen (Run), um den Prozess auszuführen.
- Nachdem die Ausführung beendet ist, können Sie zu https://platform.uipath.com navigieren und die bearbeitete Transaktion anzeigen, mit den entsprechenden Bearbeitungsdetails:
-
Erfolgreiche Transaktion
-
Fehlgeschlagene Transaktion