2022年3月18日金曜日

PythonでApache Supersetのチャート一覧を取得する

PythonでApache Supersetのチャート一覧を取得するには、以下のサンプルコードを実行します。

list-charts.py
# coding: utf-8
import pprint
import json
import requests

host = 'xxx.xxx.xxx.xxx:8080' # Supersetのホスト名またはIPアドレスとポート
user = 'admin' # ユーザ名
password = 'adminpass' # ユーザパスワード

base = "http://{}".format(host)
# ユーザ名とパスワードでアクセストークンの取得
res_login = requests.post(base + "/api/v1/security/login",
  json = {
    "password": user,
    "provider": "db",
    "refresh": True,
    "username": password
  }
)
access_token = res_login.json()['access_token']
print(access_token)

# CSRFトークンの取得
res_csrf = requests.get(base + "/api/v1/security/csrf_token",
  headers = {
    'Authorization': "Bearer {}".format(access_token)
  }
)
csrf_token = res_csrf.json()['result']
print(csrf_token)

# API呼び出し用Request headers
api_headers = {
  'Referer': base,
  'Authorization': "Bearer {}".format(access_token),
  'X-CSRFToken': csrf_token
}
# チャート一覧
res_charts = requests.get(base + "/api/v1/chart",
  headers = api_headers
)
#pprint.pprint(res_charts.json()['result'])
for chart in res_charts.json()['result']:
  print("---")
  print("chart name: {}".format(chart['slice_name'])) # チャート名
  print("visualization type: {}".format(chart['viz_type'])) # 可視化方式

・実行方法
python3 list-charts.py

関連情報

・その他のApache Supersetの情報については、以下のまとめページを参照してください。
Apache Supersetのまとめ

0 件のコメント:

コメントを投稿