Python のDash ライブラリを使って、Salesforce Data Cloud のデータ に連携するウェブアプリケーションを開発する方法

CData Python Connector を使って、Salesforce Data Cloud にデータ連携するPython ウェブアプリケーションを開発できます。pandas とDash を使って作成してみます。

加藤龍彦
デジタルマーケティング

最終更新日:2023-09-23

この記事で実現できるSalesforce Data Cloud 連携のシナリオ

こんにちは!ウェブ担当の加藤です。マーケ関連のデータ分析や整備もやっています。

Python エコシステムには、多くのモジュールがあり、システム構築を素早く効率的に行うことができます。CData Python Connector for SalesforceDataCloud を使うことで、pandas モジュールとDash フレームワークでSalesforce Data Cloud にデータ連携するアプリケーションを効率的に開発することができます。本記事では、pandas、Dash とCData Connector を使って、Salesforce Data Cloud に連携して、Salesforce Data Cloud のデータ をビジュアライズするシンプルなウェブアプリを作る方法をご紹介します。

CData Python Connectors の特徴

CData Python Connectors は、以下のような特徴を持った製品です。

  1. Salesforce Data Cloud をはじめとする、CRM、MA、会計ツールなど多様なカテゴリの270種類以上のSaaS / オンプレデータソースに対応
  2. Dash をはじめとする多様なデータ分析・BI ツールにSalesforce Data Cloud のデータを連携
  3. ノーコードでの手軽な接続設定

必要なモジュールのインストール

まずは、pip で必要なモジュールおよびフレームワークをインストールします:

pip install pandas
pip install dash
pip install dash-daq

Python でSalesforce Data Cloud のデータを可視化

必要なモジュールとフレームワークがインストールされたら、ウェブアプリを開発していきます。コードのスニペットは以下の通りです。フルコードは記事の末尾に掲載しているので、参考にしてください。

まず、CData Connector を含むモジュールをインポートします:

import os
import dash
import dash_core_components as dcc
import dash_html_components as html
import pandas as pd
import cdata.salesforcedatacloud as mod
import plotly.graph_objs as go

接続文字列を使ってデータへの接続を確立します。connect 関数を使ってCData Salesforce Data Cloud Connector からSalesforce Data Cloud のデータ との接続を確立します。

cnxn = mod.connect("InitiateOAuth=GETANDREFRESH;OAuthSettingsLocation=/PATH/TO/OAuthSettings.txt")")

Salesforce Data Cloud は、OAuth 標準による認証をサポートしています。

OAuth

AuthSchemeOAuth に設定します。

デスクトップアプリケーション

CData は、デスクトップでの認証を簡略化する埋め込みOAuth アプリケーションを提供します。

また、Salesforce Data Cloud コンソールで設定および登録するカスタムOAuth アプリケーションを介してデスクトップから認証することもできます。詳しくは、ヘルプドキュメントカスタムOAuth アプリの作成を参照してください。

接続する前に、次のプロパティを設定します。

  • InitiateOAuthGETANDREFRESHInitiateOAuth を使えば、繰り返しOAuth の交換を行ったり、手動でOAuthAccessToken を設定する必要はなくなります。
  • OAuthClientId (カスタムアプリケーションのみ):カスタムOAuth アプリケーションの登録時に割り当てられたクライアントID。
  • OAuthClientSecret (カスタムアプリケーションのみ):カスタムOAuth アプリケーションの登録時に割り当てられたクライアントシークレット。

接続すると、本製品 はデフォルトブラウザでSalesforce Data Cloud のOAuth エンドポイントを開きます。ログインして、アプリケーションにアクセス許可を与えます。

以下のようにドライバーがOAuth プロセスを完了します。

  • コールバックURL からアクセストークンを取得します。
  • 古いトークンの期限が切れたときは、新しいアクセストークンを取得します。
  • OAuthSettingsLocation にOAuth 値を保存し、接続間で永続化します。
  • Web アプリケーションやヘッドレスマシンを含むその他のOAuth メソッドについては、ヘルプドキュメントを参照してください。

    Salesforce Data Cloud にクエリを実行

    read_sql 関数を使って、padas からSQL 文を発行し、DataFrame に結果を格納します。

    df = pd.read_sql("""SELECT [Account ID], [Account Name] FROM Account WHERE EmployeeCount = '250'""", cnxn)
    

    ウェブアプリケーションの設定

    DataFrame に格納されたクエリ結果を使って、ウェブアプリにname、stylesheet、title を設定していきます。

    app_name = 'dash-salesforcedatacloudedataplot'
    
    external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
    
    app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
    app.title = 'CData + Dash'

    Layout 設定

    次に、Salesforce Data Cloud のデータ をベースにした棒グラフを作詞し、アプリのレイアウトを設定します。

    trace = go.Bar(x=df.[Account ID], y=df.[Account Name], name='[Account ID]')
    
    app.layout = html.Div(children=[html.H1("CData Extention + Dash", style={'textAlign': 'center'}),
    	dcc.Graph(
    		id='example-graph',
    		figure={
    			'data': [trace],
    			'layout':
    			go.Layout(alt='Salesforce Data Cloud Account Data', barmode='stack')
    		})
    ], className="container")
    

    アプリをセットアップして実行

    接続、アプリ、レイアウトを定義したら、アプリを実行してみましょう。以下のコードで実行できます。

    if __name__ == '__main__':
        app.run_server(debug=True)
    

    最後に、Python でウェブアプリを起動してブラウザでSalesforce Data Cloud のデータ を見てみましょう。

    python salesforcedatacloud-dash.py
    
    Dash のウェブアプリでSalesforce Data Cloud のデータ を表示

    ちゃんとデータが表示できてますね!

    おわりに

    Salesforce Data Cloud Python Connector の30日の無償トライアル をぜひダウンロードして、Salesforce Data Cloud のデータ への接続をPython アプリやスクリプトから簡単に作成してみてください。



    import os
    import dash
    import dash_core_components as dcc
    import dash_html_components as html
    import pandas as pd
    import cdata.salesforcedatacloud as mod
    import plotly.graph_objs as go
    
    cnxn = mod.connect("InitiateOAuth=GETANDREFRESH;OAuthSettingsLocation=/PATH/TO/OAuthSettings.txt")
    
    df = pd.read_sql("SELECT [Account ID], [Account Name] FROM Account WHERE EmployeeCount = '250'", cnxn)
    app_name = 'dash-salesforcedataclouddataplot'
    
    external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
    
    app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
    app.title = 'CData + Dash'
    trace = go.Bar(x=df.[Account ID], y=df.[Account Name], name='[Account ID]')
    
    app.layout = html.Div(children=[html.H1("CData Extention + Dash", style={'textAlign': 'center'}),
    	dcc.Graph(
    		id='example-graph',
    		figure={
    			'data': [trace],
    			'layout':
    			go.Layout(alt='Salesforce Data Cloud Account Data', barmode='stack')
    		})
    ], className="container")
    
    if __name__ == '__main__':
        app.run_server(debug=True)
    

関連コンテンツ

トライアル・お問い合わせ

30日間無償トライアルで、CData のリアルタイムデータ連携をフルにお試しいただけます。記事や製品についてのご質問があればお気軽にお問い合わせください。