4단계: Power BI 테이블에 행을 추가할 데이터 집합 가져오기Step 4: Get a dataset to add rows into a Power BI table

이 문서는 데이터 집합에 데이터를 푸시하는 단계별 연습의 일부입니다.This article is part of a step-by-step walkthrough to push data into a dataset.

데이터 집합에 데이터 푸시의 3단계 Power BI에서 데이터 집합 만들기에서는 데이터 집합 만들기 작업을 호출하여 Power BI에서 데이터 집합을 만들었습니다.In step 3 of Push data into a dataset, Create a dataset in Power BI, you called the Create Dataset operation to create a dataset in Power BI. 이 단계에서는 데이터 집합 가져오기 작업과 Newtonsoft.Json을 사용하여 데이터 집합 ID를 가져옵니다. 4단계의 데이터 집합 ID를 사용하여 데이터 집합에 행을 추가합니다.In this step, you use the Get Datasets operation and Newtonsoft.Json to get a dataset id. You use the dataset id in step 4 to add rows to a dataset.

데이터를 Power BI 데이터 집합으로 푸시하려면 데이터 집합의 테이블을 참조해야 합니다.To push data into a Power BI dataset, you need to reference the table in the dataset. 데이터 집합의 테이블을 참조하려면 먼저 데이터 집합 ID를 가져와야 합니다.To reference a table in a dataset, you first need to get a Dataset ID. 데이터 집합 IDID별 데이터 집합 가져오기 작업을 사용하여 가져옵니다.You get a Dataset ID using the Get Dataset By ID operation. ID별 데이터 집합 가져오기 작업은 Power BI에 있는 모든 데이터 집합의 목록이 포함된 JSON 문자열을 반환합니다.The Get Dataset By ID operation returns a JSON string containing a list of all datasets in Power BI. JSON 문자열을 역직렬화하는 데 권장되는 방법은 Newtonsoft.Json을 사용하는 것입니다.The recommended way to deserialize a JSON string is with Newtonsoft.Json.

데이터 집합을 가져오는 방법은 다음과 같습니다.Here's how you get a dataset.

Power BI 데이터 집합 가져오기Get a Power BI dataset

참고: 시작하기 전에 데이터 집합에 데이터 푸시의 이전 단계를 수행해야 합니다.NOTE: Before you get started, make sure you have followed the previous steps in the push data into a dataset walkthrough.

  1. 2단계: 데이터 푸시 연습, 인증 액세스 토큰 가져오기에서 만든 콘솔 응용 프로그램 프로젝트에서 Newtonsoft.Json NuGet 패키지를 설치합니다.In the Console Application project you created in Step 2: Walkthrough to push data, Get an authentication access token, install the Newtonsoft.Json NuGet package. 패키지를 설치하는 방법은 다음과 같습니다.Here's how to install the package:

    a.a. Visual Studio 2015에서 도구 > NuGet 패키지 관리자 > 패키지 관리자 콘솔을 선택합니다.In Visual Studio 2015, choose Tools > NuGet Package Manager > Package Manager Console.

    b.b. 패키지 관리자 콘솔에서 Install-Package Newtonsoft.Json을 입력합니다.In Package Manager Console, enter Install-Package Newtonsoft.Json.

  2. 패키지가 설치되면 using Newtonsoft.Json; 을 Program.cs에 추가합니다.After the package is installed, add using Newtonsoft.Json; to Program.cs.

  3. Program.cs에 데이터 집합 ID를 가져오는 아래 코드를 추가합니다.In Program.cs, add the code below to get a Dataset ID.

  4. 콘솔 앱을 실행하고 Power BI 계정에 로그인합니다.Run the Console App, and login to your Power BI account. 콘솔 창에 데이터 집합 ID: 다음에 ID가 표시됩니다.You should see Dataset ID: followed by an id in the Console Window.

데이터 집합 가져오기 샘플Sample get 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();
    
      //Get a dataset to add rows into a Power BI table
      string datasetId = GetDataset();
    }
    
  • GetDatset() 메서드 추가:Add a GetDatset() method:

      #region Get a dataset to add rows into a Power BI table
      private static string GetDataset()
      {
          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 = "GET";
          request.ContentLength = 0;
          request.ContentType = "application/json";
    
          //Add token to the request header
          request.Headers.Add("Authorization", String.Format("Bearer {0}", token));
    
          string datasetId = string.Empty;
          //Get HttpWebResponse from GET request
          using (HttpWebResponse httpResponse = request.GetResponse() as System.Net.HttpWebResponse)
          {
              //Get StreamReader that holds the response stream
              using (StreamReader reader = new System.IO.StreamReader(httpResponse.GetResponseStream()))
              {
                  string responseContent = reader.ReadToEnd();
    
                  //TODO: Install NuGet Newtonsoft.Json package: Install-Package Newtonsoft.Json
                  //and add using Newtonsoft.Json
                  var results = JsonConvert.DeserializeObject<dynamic>(responseContent);
    
                  //Get the first id
                  datasetId = results["value"][0]["id"];
    
                  Console.WriteLine(String.Format("Dataset ID: {0}", datasetId));
                  Console.ReadLine();
    
                  return datasetId;
              }
          }
      }
      #endregion
    

다음 단계에서는 Power BI 테이블에 행을 추가하는 방법을 보여 줍니다.The next step shows you how to add rows to 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;
using Newtonsoft.Json;

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

            //Get a dataset to add rows into a Power BI table
            string datasetId = GetDataset();

        }

        #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

        #region Get a dataset to add rows into a Power BI table
        private static string GetDataset()
        {
            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 = "GET";
            request.ContentLength = 0;
            request.ContentType = "application/json";

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

            string datasetId = string.Empty;
            //Get HttpWebResponse from GET request
            using (HttpWebResponse httpResponse = request.GetResponse() as System.Net.HttpWebResponse)
            {
                //Get StreamReader that holds the response stream
                using (StreamReader reader = new System.IO.StreamReader(httpResponse.GetResponseStream()))
                {
                    string responseContent = reader.ReadToEnd();

                    //TODO: Install NuGet Newtonsoft.Json package: Install-Package Newtonsoft.Json
                    //and add using Newtonsoft.Json
                    var results = JsonConvert.DeserializeObject<dynamic>(responseContent);

                    //Get the first id
                    datasetId = results["value"][0]["id"];

                    Console.WriteLine(String.Format("Dataset ID: {0}", datasetId));
                    Console.ReadLine();

                    return datasetId;
                }
            }
        }
        #endregion
    }
}

다음 단계 >Next Step >

다음 단계Next steps

Power BI 테이블에 행 추가Add rows to a Power BI table
Newtonsoft.JsonNewtonsoft.Json
데이터 집합 가져오기Get Datasets
Power BI로 데이터 푸시Push data into Power BI
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