Notez que cette API peut accepter plusieurs lignes de données. L’ajout d’une ligne à la fois peut affecter les performances. L’approche recommandée consiste à regrouper les lignes dans un seul appel plutôt que d’insérer des lignes uniques. Pour obtenir de meilleurs résultats, collectez les lignes à insérer côté application et effectuez une opération d’ajout de ligne unique. Testez le nombre de lignes pour déterminer le nombre idéal de lignes à utiliser dans un seul appel d’API.
Cette requête peut parfois entraîner une 504 HTTP erreur. Pour la corriger, il suffit de répéter la demande.
POST /me/drive/items/{id}/workbook/tables/{id|name}/rows
POST /me/drive/root:/{item-path}:/workbook/tables/{id|name}/rows
POST /me/drive/items/{id}/workbook/worksheets/{id|name}/tables/{id|name}/rows
POST /me/drive/root:/{item-path}:/workbook/worksheets/{id|name}/tables/{id|name}/rows
respond-async. Indique que la requête est une requête asynchrone. Optional.
Workbook-Session-Id
{Workbook-Session-Id}. Créé à partir de la requête createSession . Facultatif.
Corps de la demande
Dans le corps de la demande, indiquez un objet JSON avec les paramètres suivants.
Paramètre
Type
Description
Index
Int32
Facultatif. Spécifie la position relative de la nouvelle ligne. Si la valeur est null, la ligne est ajoutée à la fin. Toutes les lignes en dessous de la ligne insérée sont déplacées vers le bas. Avec indice zéro.
// Code snippets are only available for the latest version. Current version is 5.x
// Dependencies
using Microsoft.Graph.Models;
var requestBody = new WorkbookTableRow
{
Values = new List<List<Number>>
{
new List<Number>
{
1,
2,
3,
},
new List<Number>
{
4,
5,
6,
},
},
};
// To initialize your graphClient, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=csharp
var result = await graphClient.Drives["{drive-id}"].Items["{driveItem-id}"].Workbook.Tables["{workbookTable-id}"].Rows.PostAsync(requestBody);
// Code snippets are only available for the latest version. Current version is 6.x
GraphServiceClient graphClient = new GraphServiceClient(requestAdapter);
WorkbookTableRow workbookTableRow = new WorkbookTableRow();
LinkedList<LinkedList<Number>> values = new LinkedList<LinkedList<Number>>();
LinkedList<Number> property = new LinkedList<Number>();
property.add(1);
property.add(2);
property.add(3);
values.add(property);
LinkedList<Number> property4 = new LinkedList<Number>();
property4.add(4);
property4.add(5);
property4.add(6);
values.add(property4);
workbookTableRow.setValues(values);
WorkbookTableRow result = graphClient.drives().byDriveId("{drive-id}").items().byDriveItemId("{driveItem-id}").workbook().tables().byWorkbookTableId("{workbookTable-id}").rows().post(workbookTableRow);
Exemple 2 : Ajouter deux lignes à une table de façon asynchrone
Les requêtes asynchrones sont utiles si la demande prend plus de temps que prévu. Notez que l’en-tête Workbook-Session-Id est requis lors de l’émission de demandes asynchrones. L’utilisateur doit créer une session avant d’utiliser des fonctionnalités d’API riches asynchrones. L’en-tête Prefer:respond-async est également requis dans les requêtes asynchrones.
Voici un exemple de requête asynchrone. Notez que cela 202 Accepted se produit uniquement lorsque la réponse de la demande prend beaucoup de temps. Si la demande est effectuée rapidement, elle fonctionne comme une demande de synchronisation standard, revient à l’exemple 1.
// Code snippets are only available for the latest version. Current version is 5.x
// Dependencies
using Microsoft.Graph.Models;
var requestBody = new WorkbookTableRow
{
Values = new List<List<Number>>
{
new List<Number>
{
1,
2,
3,
},
new List<Number>
{
4,
5,
6,
},
},
};
// To initialize your graphClient, see https://learn.microsoft.com/en-us/graph/sdks/create-client?from=snippets&tabs=csharp
var result = await graphClient.Drives["{drive-id}"].Items["{driveItem-id}"].Workbook.Tables["{workbookTable-id}"].Rows.PostAsync(requestBody, (requestConfiguration) =>
{
requestConfiguration.Headers.Add("Prefer", "respond-async");
requestConfiguration.Headers.Add("Workbook-Session-Id", "{Workbook-Session-Id}");
});
// Code snippets are only available for the latest version. Current version is 6.x
GraphServiceClient graphClient = new GraphServiceClient(requestAdapter);
WorkbookTableRow workbookTableRow = new WorkbookTableRow();
LinkedList<LinkedList<Number>> values = new LinkedList<LinkedList<Number>>();
LinkedList<Number> property = new LinkedList<Number>();
property.add(1);
property.add(2);
property.add(3);
values.add(property);
LinkedList<Number> property4 = new LinkedList<Number>();
property4.add(4);
property4.add(5);
property4.add(6);
values.add(property4);
workbookTableRow.setValues(values);
WorkbookTableRow result = graphClient.drives().byDriveId("{drive-id}").items().byDriveItemId("{driveItem-id}").workbook().tables().byWorkbookTableId("{workbookTable-id}").rows().post(workbookTableRow, requestConfiguration -> {
requestConfiguration.headers.add("Prefer", "respond-async");
requestConfiguration.headers.add("Workbook-Session-Id", "{Workbook-Session-Id}");
});
Bientôt disponible : Tout au long de 2024, nous allons supprimer progressivement GitHub Issues comme mécanisme de commentaires pour le contenu et le remplacer par un nouveau système de commentaires. Pour plus d’informations, consultez https://aka.ms/ContentUserFeedback.