Externe API-Anruf Unterstützung in Office-Skripts
Skripts unterstützen Aufrufe externer Dienste. Verwenden Sie diese Dienste, um Ihrer Arbeitsmappe Daten und andere Informationen zur Verfügung zu stellen.
Achtung
Externe Aufrufe können dazu führen, dass vertrauliche Daten für unerwünschte Endpunkte verfügbar gemacht werden. Ihr Administrator kann Information Rights Management (IRM) oder Firewallschutz gegen solche Aufrufe einrichten.
Wichtig
Aufrufe externer APIs können nur über die Excel-Anwendung erfolgen, nicht über Power Automate unter normalen Umständen. Externe Aufrufe werden auch für Skripts, die auf einer SharePoint-Website gespeichert sind, nicht unterstützt.
Externe Aufrufe sind asynchron und erfordern, dass Ihr Skript als async
gekennzeichnet ist. Fügen Sie der main
Funktion das async
Präfix hinzu, und geben Sie ein Promise
zurück, wie hier gezeigt:
async function main(workbook: ExcelScript.Workbook) : Promise <void>
Hinweis
Skripts, die andere Informationen zurückgeben, können einen Promise
dieses Typs zurückgeben. Wenn Ihr Skript beispielsweise ein Employee
-Objekt zurückgeben muss, lautet die Rückgabesignatur : Promise <Employee>
Sie müssen die Schnittstellen des externen Diensts kennenlernen, um Aufrufe an diesen Dienst zu tätigen. Wenn Sie oder REST-APIs verwendenfetch
, müssen Sie die JSON-Struktur der zurückgegebenen Daten bestimmen. Erwägen Sie, sowohl für die Eingabe als auch für die Ausgabe ihres Skripts eine interface
zu erstellen, die den erforderlichen JSON-Strukturen entspricht. Dies bietet dem Skript mehr Typsicherheit. Ein Beispiel hierfür finden Sie unter Verwenden von Abrufvorgängen aus Office-Skripts.
- Es gibt keine Möglichkeit, sich anzumelden oder den OAuth2-Typ von Authentifizierungsflows zu verwenden. Alle Schlüssel und Anmeldeinformationen müssen hartcodiert sein (oder aus einer anderen Quelle gelesen werden).
- Es gibt keine Infrastruktur zum Speichern von API-Anmeldeinformationen und -schlüsseln. Dies muss vom Benutzer verwaltet werden.
- Dokumentcookies,
localStorage
- undsessionStorage
-Objekte werden nicht unterstützt. - Externe Aufrufe können dazu führen, dass vertrauliche Daten für unerwünschte Endpunkte verfügbar gemacht werden oder externe Daten in interne Arbeitsmappen gebracht werden. Ihr Administrator kann einen Firewallschutz gegen solche Aufrufe einrichten. Überprüfen Sie unbedingt lokale Richtlinien, bevor Sie externe Aufrufe verwenden.
- Überprüfen Sie unbedingt die Menge des Datendurchsatzes, bevor Sie eine Abhängigkeit übernehmen. Für instance ist das Pulldown des gesamten externen Datasets möglicherweise nicht die beste Option, und stattdessen sollte die Paginierung verwendet werden, um Daten in Blöcken abzurufen.
Die Abruf-API ruft Informationen aus externen Diensten ab. Da es sich um eine async
API handelt, müssen Sie die main
Signatur Ihres Skripts anpassen. Legen Sie die Funktion async
festmain
. Sie sollten auch auf den Aufruf und json
abruf fetch
achtenawait
. Dadurch wird sichergestellt, dass diese Vorgänge abgeschlossen werden, bevor das Skript beendet wird.
Alle von abgerufenen fetch
JSON-Daten müssen mit einer im Skript definierten Schnittstelle übereinstimmen. Der zurückgegebene Wert muss einem bestimmten Typ zugewiesen werden, da Office-Skripts den any
Typ nicht unterstützen. Informationen zu den Namen und Typen der zurückgegebenen Eigenschaften finden Sie in der Dokumentation für Ihren Dienst. Fügen Sie ihrem Skript dann die entsprechende Schnittstelle oder Schnittstellen hinzu.
Das folgende Skript verwendet fetch
zum Abrufen von JSON-Daten vom Testserver in der angegebenen URL. Beachten Sie die JSONData
Schnittstelle zum Speichern der Daten als übereinstimmenden Typ.
async function main(workbook: ExcelScript.Workbook) {
// Retrieve sample JSON data from a test server.
let fetchResult = await fetch('https://jsonplaceholder.typicode.com/todos/1');
// Convert the returned data to the expected JSON structure.
let json : JSONData = await fetchResult.json();
// Display the content in a readable format.
console.log(JSON.stringify(json));
}
/**
* An interface that matches the returned JSON structure.
* The property names match exactly.
*/
interface JSONData {
userId: number;
id: number;
title: string;
completed: boolean;
}
- Das Beispiel Verwenden externer Abrufaufrufe in Office-Skripts zeigt, wie Sie grundlegende Informationen zu den GitHub-Repositorys eines Benutzers abrufen.
- Beispiele im Artikel Verwenden von JSON zum Übergeben von Daten an und aus Office-Skripts zeigen, wie Daten als JSON an und von
fetch
Befehlen übergeben werden. - Das Beispielszenario office scripts: Graph water-level data from NOAA veranschaulicht den Befehl, der
fetch
zum Abrufen von Datensätzen aus der Tides and Currents-Datenbank der National Oceanic and Atmospheric Administration verwendet wird. - Das zweite Beispiel unter Hinzufügen von Bildern zu einer Arbeitsmappe enthält einen
fetch
Aufruf zum Abrufen eines Bilds von einer Website.
Sie können IRM-Einstellungen auf eine Arbeitsmappe anwenden, um zu verhindern, dass externe Aufrufe von Skripts erfolgen. Deaktivieren Sie die Copy/EXTRACT-Richtlinie, um dieses Verhalten zu verhindern.
Externe API-Aufrufe schlagen fehl, wenn ein Skript über Power Automate ausgeführt wird. Ein fetch
Aufruf gibt die Fehlermeldung "Runtime error: Line X: fetch is not defined" (Laufzeitfehler: Zeile X: Fetch ist nicht definiert) aus. Überprüfen Sie ihre Skripts auf solche Verweise, bevor Sie sie in einen Flow integrieren.
Sie müssen HTTP mit Azure AD oder anderen äquivalenten Aktionen verwenden, um Daten aus einem externen Dienst zu pullen oder zu pushen.
Warnung
Externe Aufrufe, die über den Power Automate Excel Online-Connector ausgeführt werden, schlagen fehl, um vorhandene Richtlinien zur Verhinderung von Datenverlust aufrechtzuerhalten. Skripts, die über Power Automate ausgeführt werden, werden jedoch außerhalb Ihrer organization und außerhalb der Firewalls Ihres organization ausgeführt. Für zusätzlichen Schutz vor böswilligen Benutzern in dieser externen Umgebung kann Ihr Administrator die Verwendung von Office-Skripts steuern. Ihr Administrator kann entweder den Excel Online-Connector in Power Automate deaktivieren oder Office-Skripts für Excel über die Office-Skripts-Administratorsteuerelemente deaktivieren.
Feedback zu Office Scripts
Office Scripts ist ein Open Source-Projekt. Wählen Sie einen Link aus, um Feedback zu geben: