Etapa 3: Criar um conjunto de dados no Power BIStep 3: Create a dataset in Power BI

Este artigo faz parte do passo a passo para enviar dados por push a um conjunto de dados.This article is part of a step-by-step walkthrough to push data into a dataset.

Na etapa 2, Obter um token de acesso de autenticação, de Enviar dados por push a um conjunto de dados, você obteve um token para autenticar-se no Azure AD.In step 2 of Push data into a dataset, Get an authentication access token, you got a token to authenticate to Azure AD. Nesta etapa, você usa o token para chamar a operação Criar Conjunto de DadosIn this step, you use the token to call the Create Dataset operation.

Para fazer uma chamada para um recurso REST, você usa uma URL que localiza o recurso e envia uma cadeia de caracteres JSON (JavaScript Object Notation), que descreve o conjunto de dados, ao recurso de serviço do Power BI.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. Um recurso REST identifica a parte do serviço do Power BI com que você deseja trabalhar.A REST resource identifies the part of the Power BI service you want to work with. Para enviar dados por push ao conjunto de dados, o recurso de destino é um Conjunto de Dados.To push data into the dataset, the target resource is a Dataset. A URL que identifica um conjunto de dados é https://api.PowerBI.com/v1.0/myorg/datasets.The URL that identifies a dataset is https://api.PowerBI.com/v1.0/myorg/datasets. Se você estiver enviando dados por push em um grupo, a URL será https://api.PowerBI.com/v1.0/myorg/groups/{id_grupo}/datasets.If you are pushing data within a group, the url is https://api.PowerBI.com/v1.0/myorg/groups/{group_id}/datasets.

Para autenticar uma operação REST do Power BI, você adiciona o token que recebeu em Obter um token de acesso de autenticação a um cabeçalho de solicitação:To authenticate a Power BI REST operation, you add the token you got in Get an authentication access token to a request header:

Quando você chama a operação Criar Conjunto de Dados, um novo conjunto de dados é criado.When you call the Create Dataset operation, a new dataset is created.

Veja como criar um conjunto de dados no Power BI.Here's how to create a dataset in Power BI.

Criar um conjunto de dados no Power BICreate a dataset in Power BI

Observação

Antes de começar, lembre-se de seguir as etapas anteriores no passo a passo enviar dados por push a um conjunto de dados.Before you get started, make sure you have followed the previous steps in the push data into a dataset walkthrough.

  1. No projeto de Aplicativo de Console criado na Etapa 2 – Obter um token de acesso de autenticação, adicione using System.Net; e using System.IO; a Program.cs.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. Em Program.cs, adicione o código a seguir.In Program.cs, add the code below.
  3. Execute o Aplicativo de Console e faça logon na sua conta do Power BI.Run the Console App, and login to your Power BI account. Você deve ver Conjunto de Dados Criado na janela do Console.You should see Dataset Created in the Console Window. Além disso, você pode fazer logon no Power BI para ver o novo conjunto de dados.Also, you can login to Power BI to see the new dataset.

Exemplo de envio dados por push a um conjunto de dadosSample push data into a dataset

Adicione este código a Program.cs.Add this code into Program.cs.

  • Em 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();
    }
    
  • Adicione um método CreateDataset():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
    

A próxima etapa mostra como obter um conjunto de dados para adicionar linhas a uma tabela do Power BI.The next step shows you how to get a dataset to add rows into a Power BI table.

Apresentamos abaixo a listagem de código completa.Below is the complete code listing.

Listagem de código completoComplete 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
    }
}

Próxima etapa >Next Step >

Próximas etapasNext steps

Obter um conjunto de dados para adicionar linhas em uma tabela do Power BIGet a dataset to add rows into a Power BI table
Obter um token de acesso de autenticaçãoGet an authentication access token
Criar conjunto de dadosCreate Dataset
Enviar dados por push a um Dashboard do Power BIPush data into a Power BI Dashboard
Visão geral da API REST do Power BIOverview of Power BI REST API
Referência da API REST do Power BIPower BI REST API reference

Mais perguntas?More questions? Experimente a Comunidade do Power BITry the Power BI Community