JayDeBeApi を使って Python からZendesk のデータにアクセス
Python と Java がインストールされている環境であれば、Python スクリプトと標準 SQL を使ってZendesk のデータにアクセスできます。CData JDBC Driver for Zendesk と JayDeBeApi モジュールを組み合わせることで、Python からリモートのZendesk のデータを操作できます。CData ドライバーを使用することで、業界標準に準拠した実績のあるドライバーを Python という人気の高い言語で活用できます。この記事では、ドライバーを使って Zendesk に SQL クエリを実行し、標準的な Python でZendesk のデータを可視化する方法を説明します。
JayDeBeApi モジュールを使用
JayDeBeApi は、JDBC(Java Database Connectivity)のブリッジとして機能する Python ライブラリで、Python プログラムから CData JDBC ドライバーを含む Java データベースとやり取りできるようになります。pip install コマンドでモジュールをインストールします。
pip install JayDeBeApi
JDBC URL を作成
JayDeBeApi をインストールしたら、SQL を使って Python からZendesk のデータを操作する準備が整います。
Zendesk 接続プロパティの取得・設定方法
Zendesk に接続するには、https://{subdomain}.zendesk.com の形式でURL(Zendesk Support URL)を設定します。接続後、次のセクションの説明に従ってユーザー認証を行います。
また、TicketMetrics テーブルのアーカイブデータを扱うユーザーは、UseIncrementalAPI プロパティをTrue に設定する必要があります。
Zendesk への認証
Zendesk は、Zendesk インスタンスの設定に応じて、3種類の認証をサポートします。API トークン認証、OAuth 認証、Basic 認証(レガシー)です。
API トークン認証
API トークン認証を使用する場合は、E メールアドレスとApiToken を指定します。 AuthScheme をAPIToken に、User をE メールアドレスに設定し、Zendesk Support の管理画面で以下の設定を行います。
- Token アクセスを有効にします。
- Admin -> Channels-> API で、API トークンを管理します。一度にアクティブにできるトークンは1つだけです。トークンを削除すると、そのトークンは永久に無効化されます。
その他の認証方法についてはヘルプドキュメントを参照してください。
ビルトイン接続文字列デザイナー
JDBC URL の作成には、Zendesk JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルをダブルクリックするか、コマンドラインから実行します。
java -jar cdata.jdbc.zendesk.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
以下は、一般的な JDBC 接続文字列を含む変数の例です。
jdbc_url = "jdbc:zendesk:URL=https://subdomain.zendesk.com;[email protected];Password=test123;"
Python からZendesk のデータにアクセス
JDBC URL を設定したら、あとは JDBC ドライバーの JAR ファイルへの絶対パスだけが必要です。これはインストールディレクトリの "lib" フォルダにあります(Windows では "C:\Program Files\CData[product_name] 20XX\lib\cdata.jdbc.zendesk.jar")。
注意: まだ設定していない場合は、JAVA_HOME 環境変数を Java のインストールディレクトリに設定してください。
以下のようなコードで Zendesk からデータを読み取り、表示できます。
import jaydebeapi #The JDBC connection string jdbc_url = "jdbc:zendesk:URL=https://subdomain.zendesk.com;[email protected];Password=test123;" username = "****" password = "****" #The absolute Path to the JDBC driver JAR file, typically: jdbc_driver_jar = "C:\Program Files\CData[product_name] 20XX\lib\cdata.jdbc.zendesk.jar" conn = jaydebeapi.connect( "cdata.jdbc.zendesk.ZendeskDriver", jdbc_url, [username, password], jdbc_driver_jar, ) cursor = conn.cursor() cursor.execute("SELECT * FROM Tickets;") results = cursor.fetchall() for row in results: print(row) cursor.close() conn.close()
無料トライアルと詳細情報
CData JDBC Driver for Zendesk の 30 日間無料トライアルをダウンロードして、Python でリアルタイムのZendesk のデータを操作してみてください。ご不明な点がございましたら、サポートチームまでお問い合わせください。