Schritt 3: Erstellen eines Datasets in Power BIStep 3: Create a dataset in Power BI

Dieser Artikel ist Teil einer Anleitung zum Übertragen von Daten in ein Dataset per Push.This article is part of a step-by-step walkthrough to push data into a dataset.

In Schritt 2 von „Übertragen von Daten in ein Dataset per Push“ (Abrufen eines Authentifizierungszugriffstokens) haben Sie ein Token für die Authentifizierung bei Azure AD abgerufen.In step 2 of Push data into a dataset, Get an authentication access token, you got a token to authenticate to Azure AD. In diesem Schritt verwenden Sie das Token zum Aufrufen des Vorgangs Dataset erstellen.In this step, you use the token to call the Create Dataset operation.

Um einen Aufruf einer anderen Ressource zu erstellen, verwenden Sie eine URL zum Bestimmen der Ressource und senden eine JSON-Zeichenfolge (JavaScript Object Notation), die das Dataset beschreibt, an die Power BI-Dienstressource.To make a call to a REST resource, you use a url that locates the resource, and you send a JavaScript Object Notation (JSON) string, which describes the dataset, to the Power BI service resource. Eine REST-Ressource gibt den Teil des Power BI-Diensts an, mit dem Sie arbeiten möchten.A REST resource identifies the part of the Power BI service you want to work with. Beim Übertragen von Daten per Push in das Dataset ist die Zielressource ein Dataset.To push data into the dataset, the target resource is a Dataset. Die URL zum Identifizieren eines Datasets lautet https://api.PowerBI.com/v1.0/myorg/datasets.The URL that identifies a dataset is https://api.PowerBI.com/v1.0/myorg/datasets. Wenn Sie Daten per Push innerhalb einer Gruppe übertragen, lautet die URL https://api.PowerBI.com/v1.0/myorg/groups/{Gruppen_ID}/datasets.If you are pushing data within a group, the url is https://api.PowerBI.com/v1.0/myorg/groups/{group_id}/datasets.

Zum Authentifizieren eines Power BI-REST-Vorgangs fügen Sie das unter Abrufen eines Authentifizierungszugriffstokens abgerufene Token einem Anforderungsheader hinzu:To authenticate a Power BI REST operation, you add the token you got in Get an authentication access token to a request header:

Durch Aufrufen des Vorgangs Dataset erstellen wird ein neues Dataset erstellt.When you call the Create Dataset operation, a new dataset is created.

Im Folgenden wird das Erstellen eines Datasets in Power BI erläutert.Here's how to create a dataset in Power BI.

Erstellen eines Datasets in Power BICreate a dataset in Power BI

Hinweis

Wichtig ist, dass Sie zuvor die vorangegangenen Schritte der exemplarischen Vorgehensweise Übertragen von Daten in ein Dataset per Push ausgeführt haben.Before you get started, make sure you have followed the previous steps in the push data into a dataset walkthrough.

  1. Im Konsolenanwendungsprojekt, das Sie in Schritt 2: Abrufen eines Authentifizierungszugriffstokens erstellt haben, fügen Sie der Datei „Program.cs“ die Einträge using System.Net; und using System.IO; hinzu.In the Console Application project you created in Step 2 - Get an authentication access token, add using System.Net;, and using System.IO; to Program.cs.
  2. Fügen Sie „Program.cs“ den folgenden Code hinzu.In Program.cs, add the code below.
  3. Führen Sie die Konsolen-App aus, und melden Sie sich bei Ihrem Power BI-Konto an.Run the Console App, and login to your Power BI account. Daraufhin sollte im Konsolenfenster Dataset erstellt angezeigt werden.You should see Dataset Created in the Console Window. Sie können sich auch bei Power BI anmelden, um das neue Dataset anzuzeigen.Also, you can login to Power BI to see the new dataset.

Beispiel für das Übertragen von Daten in ein Dataset per PushSample push data into a dataset

Fügen Sie diesen Code der Datei „Program.cs“ hinzu.Add this code into Program.cs.

  • In „static void Main(string[]args)“:In static void Main(string[] args):

    static void Main(string[] args)
    {
        //Get an authentication access token
        token = GetToken();
    
        //Create a dataset in Power BI
        CreateDataset();
    }
    
  • Fügen Sie eine „CreateDataset()“-Methode hinzu:Add a CreateDataset() method:

    #region Create a dataset in Power BI
    private static void CreateDataset()
    {
        //TODO: Add using System.Net and using System.IO
    
        string powerBIDatasetsApiUrl = "https://api.powerbi.com/v1.0/myorg/datasets";
        //POST web request to create a dataset.
        //To create a Dataset in a group, use the Groups uri: https://api.PowerBI.com/v1.0/myorg/groups/{group_id}/datasets
        HttpWebRequest request = System.Net.WebRequest.Create(powerBIDatasetsApiUrl) as System.Net.HttpWebRequest;
        request.KeepAlive = true;
        request.Method = "POST";
        request.ContentLength = 0;
        request.ContentType = "application/json";
    
        //Add token to the request header
        request.Headers.Add("Authorization", String.Format("Bearer {0}", token));
    
        //Create dataset JSON for POST request
        string datasetJson = "{\"name\": \"SalesMarketing\", \"tables\": " +
            "[{\"name\": \"Product\", \"columns\": " +
            "[{ \"name\": \"ProductID\", \"dataType\": \"Int64\"}, " +
            "{ \"name\": \"Name\", \"dataType\": \"string\"}, " +
            "{ \"name\": \"Category\", \"dataType\": \"string\"}," +
            "{ \"name\": \"IsCompete\", \"dataType\": \"bool\"}," +
            "{ \"name\": \"ManufacturedOn\", \"dataType\": \"DateTime\"}" +
            "]}]}";
    
        //POST web request
        byte[] byteArray = System.Text.Encoding.UTF8.GetBytes(datasetJson);
        request.ContentLength = byteArray.Length;
    
        //Write JSON byte[] into a Stream
        using (Stream writer = request.GetRequestStream())
        {
            writer.Write(byteArray, 0, byteArray.Length);
    
            var response = (HttpWebResponse)request.GetResponse();
    
            Console.WriteLine(string.Format("Dataset {0}", response.StatusCode.ToString()));
    
            Console.ReadLine();
        }
    }
    #endregion
    

Im nächsten Schritt erfahren Sie, wie Sie ein Dataset zum Hinzufügen von Zeilen zu einer Power BI-Tabelle abrufen.The next step shows you how to get a dataset to add rows into a Power BI table.

Nachstehend finden Sie die vollständige Codeliste.Below is the complete code listing.

Vollständige CodelisteComplete code listing

using System;
using Microsoft.IdentityModel.Clients.ActiveDirectory;
using System.Net;
using System.IO;

namespace walkthrough_push_data
{
    class Program
    {
        private static string token = string.Empty;

        static void Main(string[] args)
        {

            //Get an authentication access token
            token = GetToken();

            //Create a dataset in Power BI
            CreateDataset();

        }

        #region Get an authentication access token
        private static string GetToken()
        {
            // TODO: Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory -Version 2.21.301221612
            // and add using Microsoft.IdentityModel.Clients.ActiveDirectory

            //The client id that Azure AD created when you registered your client app.
            string clientID = "{Client_ID}";

            //RedirectUri you used when you register your app.
            //For a client app, a redirect uri gives Azure AD more details on the application that it will authenticate.
            // You can use this redirect uri for your client app
            string redirectUri = "https://login.live.com/oauth20_desktop.srf";

            //Resource Uri for Power BI API
            string resourceUri = "https://analysis.windows.net/powerbi/api";

            //OAuth2 authority Uri
            string authorityUri = "https://login.windows.net/common/oauth2/authorize";

            //Get access token:
            // To call a Power BI REST operation, create an instance of AuthenticationContext and call AcquireToken
            // AuthenticationContext is part of the Active Directory Authentication Library NuGet package
            // To install the Active Directory Authentication Library NuGet package in Visual Studio,
            //  run "Install-Package Microsoft.IdentityModel.Clients.ActiveDirectory" from the nuget Package Manager Console.

            // AcquireToken will acquire an Azure access token
            // Call AcquireToken to get an Azure token from Azure Active Directory token issuance endpoint
            AuthenticationContext authContext = new AuthenticationContext(authorityUri);
            string token = authContext.AcquireToken(resourceUri, clientID, new Uri(redirectUri)).AccessToken;

            Console.WriteLine(token);
            Console.ReadLine();

            return token;
        }

        #endregion


        #region Create a dataset in Power BI
        private static void CreateDataset()
        {
            //TODO: Add using System.Net and using System.IO

            string powerBIDatasetsApiUrl = "https://api.powerbi.com/v1.0/myorg/datasets";
            //POST web request to create a dataset.
            //To create a Dataset in a group, use the Groups uri: https://api.PowerBI.com/v1.0/myorg/groups/{group_id}/datasets
            HttpWebRequest request = System.Net.WebRequest.Create(powerBIDatasetsApiUrl) as System.Net.HttpWebRequest;
            request.KeepAlive = true;
            request.Method = "POST";
            request.ContentLength = 0;
            request.ContentType = "application/json";

            //Add token to the request header
            request.Headers.Add("Authorization", String.Format("Bearer {0}", token));

            //Create dataset JSON for POST request
            string datasetJson = "{\"name\": \"SalesMarketing\", \"tables\": " +
                "[{\"name\": \"Product\", \"columns\": " +
                "[{ \"name\": \"ProductID\", \"dataType\": \"Int64\"}, " +
                "{ \"name\": \"Name\", \"dataType\": \"string\"}, " +
                "{ \"name\": \"Category\", \"dataType\": \"string\"}," +
                "{ \"name\": \"IsCompete\", \"dataType\": \"bool\"}," +
                "{ \"name\": \"ManufacturedOn\", \"dataType\": \"DateTime\"}" +
                "]}]}";

            //POST web request
            byte[] byteArray = System.Text.Encoding.UTF8.GetBytes(datasetJson);
            request.ContentLength = byteArray.Length;

            //Write JSON byte[] into a Stream
            using (Stream writer = request.GetRequestStream())
            {
                writer.Write(byteArray, 0, byteArray.Length);

                var response = (HttpWebResponse)request.GetResponse();

                Console.WriteLine(string.Format("Dataset {0}", response.StatusCode.ToString()));

                Console.ReadLine();
            }
        }
        #endregion
    }
}

Nächster Schritt >Next Step >

Nächste SchritteNext steps

Abrufen eines Datasets, um einer Power BI-Tabelle Zeilen hinzuzufügenGet a dataset to add rows into a Power BI table
Abrufen eines AuthentifizierungszugriffstokensGet an authentication access token
Create Dataset (Dataset erstellen)Create Dataset
Übertragung von Daten in ein Power BI-Dashboard per PushPush data into a Power BI Dashboard
Übersicht über Power BI-REST-APIOverview of Power BI REST API
Referenz zur Power BI-REST-APIPower BI REST API reference

Weitere Fragen?More questions? Wenden Sie sich an die Power BI-CommunityTry the Power BI Community