当サイトでは実際に購入した商品のみをレビューし、アフェリエイトリンク付きでご紹介しています
【Python】Plotly.Expressでインタラクティブな折れ線グラフを作る
data:image/s3,"s3://crabby-images/2a2ac/2a2ac2f4d798835065fd796c7ece50653d982147" alt="【Python】Search Consoleのデータでインタラクティブな動的グラフを作る【Plotly.Express】【WordPress】"
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
Search Consoleのデータを、インタラクティブなグラフにして、WordPressへ表示する方法をご紹介します。
Plotly.Expressを使って、とてもカンタンに実現できます。プログラミング初心者にもオススメです!
- インタラクティブなグラフとは?
- Plotlyとは?
- Plotly.Expressの使い方
- Search Consoleの結果をグラフにする方法
- Plotlyで作成したグラフを、WordPressのサイトに載せる方法
インタラクティブなグラフとは?
このグラフは、2021年4月のこのサイトのサーチコンソールの結果データです。
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
操作によって、グラフの表示を変更できます!
たとえば…
- 折れ線グラフにカーソルを合わせると、数値が表示される
- variableをクリックすると、表示するグラフを選択できる
今回は「PythonのPlotly.Expressで、HTMLを生成する」という方法で実現しました。
data:image/s3,"s3://crabby-images/b2996/b2996ddf60d24c9a9cfcde76203cee41b38311d0" alt=""
data:image/s3,"s3://crabby-images/b2996/b2996ddf60d24c9a9cfcde76203cee41b38311d0" alt=""
data:image/s3,"s3://crabby-images/b2996/b2996ddf60d24c9a9cfcde76203cee41b38311d0" alt=""
WordPressのプラグインじゃ、ダメなの?
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
もちろん、プラグインでもOKです。
「プラグインを増やしたくない」「Pythonの開発環境がある」というときに、Plotly.Expressはオススメです。
Plotlyとは?
「Plotly」とは、データ可視化のプラットフォームです。インタラクティブなグラフを作ることができます。
Plotlyというカナダの企業が開発しており、Python・R・JavaScriptなど、いろいろな環境からAPIを実行することができます。
「Plotly.Express」とは、便利なPlotlyを、更にカンタンに使うことができるPythonのライブラリです。
data:image/s3,"s3://crabby-images/b2569/b2569fd3d5644de773464d3c4d5d80842c9b7c84" alt="猫の挿絵003"
data:image/s3,"s3://crabby-images/b2569/b2569fd3d5644de773464d3c4d5d80842c9b7c84" alt="猫の挿絵003"
Plotly.Expressの使い方
サーチコンソールのデータをCSVに保存する
- Google Search Consoleにログイン
- 「検索パフォーマンス」をクリック
- 表示日付を選択する
- 「エクスポート」ボタンをクリック
- 「CSVをダウンロード」をクリック
- お使いのパソコンの任意の場所にCSVデータを保存する
【初回のみ】追加ライブラリをインストールする
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
ここからは、Python開発環境「Anaconda」のインストールが必要です。
- ターミナルを起動する
- pip install pandas を入力し、実行
- pip install plotly を入力し、実行
pip install plotly
Collecting plotly
Downloading plotly-4.14.3-py2.py3-none-any.whl (13.2 MB)
|████████████████████████████████| 13.2 MB 10.2 MB/s
Requirement already satisfied: six in ./opt/anaconda3/lib/python3.8/site-packages (from plotly) (1.15.0)
Collecting retrying>=1.3.3
Downloading retrying-1.3.3.tar.gz (10 kB)
Building wheels for collected packages: retrying
Building wheel for retrying (setup.py) ... done
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
plotlyのインストールに成功すると、ターミナルにこのような表示がされます。
Jupiter Notebookを起動し、コードを貼り付ける
- Anaconda-Navigaterをクリック
- Jupiter Notebookをクリック
- 入力欄に以下のコードを貼り付ける
- 3行目にCSVのフルパスを入力
- 「実行」をクリック
import pandas as pd
import plotly.express as px
df = pd.read_csv('★ここは保存したCSVのフルパスに書き換えてください★')
fig = px.line(data_frame=df,x='日付',y=['クリック数','表示回数'],color_discrete_sequence=['blue','purple'])
fig.to_html(include_plotlyjs='cdn',full_html=False).encode().decode('unicode-escape')
たったこれだけで、動的グラフのHTMLが生成できます。
data:image/s3,"s3://crabby-images/4a06e/4a06ec270a62abb3f396a63f812794fb04753279" alt="Jupiter Notebookを起動し、Pythonコードを貼り付ける"
data:image/s3,"s3://crabby-images/4a06e/4a06ec270a62abb3f396a63f812794fb04753279" alt="Jupiter Notebookを起動し、Pythonコードを貼り付ける"
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
わずか5行!
WordPressにグラフのHTMLを貼り付ける
- WordPressにログインし、編集画面を開く
- 「カスタムHTML」のブロックを追加する
- Pythonで生成したHTMLを貼り付ける
- scriptタグ付近にある「\n」を、手動で削除する
- 正常に表示できるか、プレビューをする
- 記事を保存して、完成!
data:image/s3,"s3://crabby-images/e5c84/e5c842953c9556212775722bd1327a6a99153cf3" alt="WordPressにグラフのHTMLを貼り付ける"
data:image/s3,"s3://crabby-images/e5c84/e5c842953c9556212775722bd1327a6a99153cf3" alt="WordPressにグラフのHTMLを貼り付ける"
カスタムHTMLに含めず、削除すべきもの
- 文頭のシングルコーテーション
- 文末のシングルコーテーション
- scriptタグ付近にある\n
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
data:image/s3,"s3://crabby-images/61e07/61e07e5e4a7350e87eda8d9c3017b3b9d570eebf" alt=""
できました!カンタン。
発生した課題と回避方法
- 日本語がUnicodeで表示されてしまい、読めない。
→生成したHTMLを、デコードし直した。(.encode().decode(‘unicode-escape’)の部分) - 表示回数とクリック回数が大きく異なるため、クリック回数が底辺を這うようなグラフになってしまう
→2軸表示にしたい。
2軸のグラフの作り方は、こちらの記事にまとめました。よろしければ、ご一読ください。
data:image/s3,"s3://crabby-images/ae754/ae75463f335243bb808dca8809fbbd21cce81ea5" alt=""
data:image/s3,"s3://crabby-images/ae754/ae75463f335243bb808dca8809fbbd21cce81ea5" alt=""
data:image/s3,"s3://crabby-images/5680e/5680e5c43a5acaeb6954bce8812c1ec69bd7c697" alt="猫の挿絵"
data:image/s3,"s3://crabby-images/5680e/5680e5c43a5acaeb6954bce8812c1ec69bd7c697" alt="猫の挿絵"
参考サイト
今回のスクリプトの作成にあたり、以下の記事を参考にさせていただきました。
ありがとうございます。
data:image/s3,"s3://crabby-images/913d0/913d0fd38ea69fc9ca9c75d361bb6c636de5aba7" alt=""
data:image/s3,"s3://crabby-images/913d0/913d0fd38ea69fc9ca9c75d361bb6c636de5aba7" alt=""
まとめ
たった5行で、これほどのグラフを作れるとは、驚きます。
他言語ならば、FileSystemクラスを呼び出して、CSVファイルをオープンするだけで、5行終わりそうです。
Plotly.Expressは、コストパフォーマンスが素晴らしいライブラリだと感じました。
今後も、Plotly.Expressについて、勉強していきます。
サイトのデータを公開する場面で、生かしていきたいです。
data:image/s3,"s3://crabby-images/3d21a/3d21a9e79de84378314bbd290d13245e6a7ed981" alt=""
data:image/s3,"s3://crabby-images/3d21a/3d21a9e79de84378314bbd290d13245e6a7ed981" alt=""
最後まで読んでいただき、ありがとうございました。
みなさまの暮らしがより良くなりますように。