手順 3: Power BI でデータセットを作成するStep 3: Create a dataset in Power BI

この記事は、チュートリアル「データセットにデータをプッシュする」の一部です。This article is part of a step-by-step walkthrough to push data into a dataset.

チュートリアル「データセットにデータをプッシュする」の手順 2認証アクセス トークンを取得する」では、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. この手順では、そのトークンを使ってデータセットの作成操作を呼び出します。In this step, you use the token to call the Create Dataset operation.

REST リソースを呼び出すには、リソースを指定する URL を使って、Power BI サービス リソースに JavaScript Object Notation (JSON) 文字列 (データセットを記述したもの) を送信します。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. REST リソースは、Power BI サービスのうち操作する部分を識別します。A REST resource identifies the part of the Power BI service you want to work with. データセットにデータをプッシュする場合、対象のリソースはデータセットです。To push data into the dataset, the target resource is a Dataset. データセットを識別する URL は、https://api.PowerBI.com/v1.0/myorg/datasets です。The URL that identifies a dataset is https://api.PowerBI.com/v1.0/myorg/datasets. グループ内にデータをプッシュする場合の URL は、https://api.PowerBI.com/v1.0/myorg/groups/{group_id}/datasets です。If you are pushing data within a group, the url is https://api.PowerBI.com/v1.0/myorg/groups/{group_id}/datasets.

Power BI REST 操作を認証するには、認証アクセス トークンを取得する手順で入手したトークンを要求ヘッダーに追加します。To authenticate a Power BI REST operation, you add the token you got in Get an authentication access token to a request header:

データセットの作成操作を呼び出すと、新しいデータセットが作成されます。When you call the Create Dataset operation, a new dataset is created.

Power BI でデータセットを作成する手順は次のとおりです。Here's how to create a dataset in Power BI.

Power BI でデータセットを作成するCreate a dataset in Power BI

注意

作業を開始する前に、チュートリアル「データセットにデータをプッシュする」の前の手順を完了してください。Before you get started, make sure you have followed the previous steps in the push data into a dataset walkthrough.

  1. 手順 2: 認証アクセス トークンを取得する」で作成したコンソール アプリケーション プロジェクトで、Program.cs に「using System.Net;」と「using System.IO;」を追加します。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. Program.cs に、以下のコードを追加します。In Program.cs, add the code below.
  3. コンソール アプリを実行し、Power BI アカウントにログインします。Run the Console App, and login to your Power BI account. コンソール ウィンドウに、 作成されたデータセット が表示されるはずです。You should see Dataset Created in the Console Window. また、Power BI にログインして、新しいデータセットを表示することもできます。Also, you can login to Power BI to see the new dataset.

データセットにデータをプッシュするサンプルSample push data into a dataset

このコードを Program.cs に追加します。Add this code into Program.cs.

  • 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();
    }
    
  • 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
    

次の手順では、Power BI テーブルに行を追加するためにデータセットを取得する方法を説明します。The next step shows you how to get a dataset to add rows into a Power BI table.

以下は、完全なコード リストです。Below is the complete code listing.

完全なコード リストComplete 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
    }
}

次の手順 >Next Step >

次の手順Next steps

Power BI テーブルに行を追加するためにデータセットを取得するGet a dataset to add rows into a Power BI table
認証アクセス トークンを取得するGet an authentication access token
データセットの作成Create Dataset
Power BI ダッシュボードにデータをプッシュするPush data into a Power BI Dashboard
Power BI REST API の概要Overview of Power BI REST API
Power BI REST API リファレンスPower BI REST API reference

他にわからないことがある場合は、More questions? Power BI コミュニティを利用してくださいTry the Power BI Community