Google Vis Pythonで試みる

クソ記事を量産中です。

スポンサーリンク

必要となる知識や準備等

必要となる知識

  • いろんあグラフが使えるGoogle Visualization API
  • Google Visualization APIは基本 JavaScript で使います
  • pythonで試みるとはいえ、実質Jsonを用意するだけ
  • なんかJson用意すればとりあえずそれが使えるっぽい
  • ネット接続が必須

Google Visは多機能っぽいのに、ネットが必須ってのではっきり萎えました。やる気0です。でも試す価値はあるかもしれません。

pythonとGoogle Visを連載させるための準備

Anaconda Promptで以下。

pip install gviz_api

はっきりいってたぶんpythonいらん。javascriptだけでいい。でもそれでもやりたいって人はどうぞ。

スポンサーリンク

pythonでGoogle Vis用のソースを全部吐き出す

正直いうとこちらは上記のgithubサンプルコードのトレースです。なんかJsonが鍵っぽいです。

ちょっとアレンジ加えました。htmlファイルを作って、それをwebbrowser.open(”)で開くようにしました。終わったらos.remove()でファイルを削除します。こんなアホなコードかくの自分くらいじゃねえかと思えてくる。

import os, webbrowser
import gviz_api

page_template = """
<html>
  <head>
  <title>Static example</title>
    <script src="http://www.google.com/jsapi" type="text/javascript"></script>
    <script>
      google.load("visualization", "1", {packages:["table"]});
      google.setOnLoadCallback(drawTable);
      function drawTable() {
        %(jscode)s
        var jscode_table = new google.visualization.Table(document.getElementById('table_div_jscode'));
        jscode_table.draw(jscode_data, {showRowNumber: true});
        var json_table = new google.visualization.Table(document.getElementById('table_div_json'));
        var json_data = new google.visualization.DataTable(%(json)s, 0.5);
        json_table.draw(json_data, {showRowNumber: true});
      }
    </script>
  </head>
  <body>
    <H1>Table created using ToJSCode</H1>
    <div id="table_div_jscode"></div>
    <H1>Table created using ToJSon</H1>
    <div id="table_div_json"></div>
  </body>
</html>
"""


def main():
  # Creating the data
  description = {"name": ("string", "Name"),
                 "salary": ("number", "Salary"),
                 "full_time": ("boolean", "Full Time Employee")}
  data = [{"name": "Mike", "salary": (10000, "$10,000"), "full_time": True},
          {"name": "Jim", "salary": (800, "$800"), "full_time": False},
          {"name": "Alice", "salary": (12500, "$12,500"), "full_time": True},
          {"name": "Bob", "salary": (7000, "$7,000"), "full_time": True}]

  # Loading it into gviz_api.DataTable
  data_table = gviz_api.DataTable(description)
  data_table.LoadData(data)

  # Creating a JavaScript code string
  jscode = data_table.ToJSCode("jscode_data",
                               columns_order=("name", "salary", "full_time"),
                               order_by="salary")
  # Creating a JSon string
  json = data_table.ToJSon(columns_order=("name", "salary", "full_time"),
                           order_by="salary")

  # Putting the JS code and JSon string into the template
  with open("sample.html", "w") as f:
      f.write(page_template % vars())

  webbrowser.open("C:/Users/xxxxxx/Desktop/sample.html")
  input("Is Delete?: ")
  os.remove("sample.html")

if __name__ == "__main__":
  main()

結果

python google vis

なんでネット環境がないとだめなの?オフラインでも使えるようにしてよグーグル。

雑感

だるい。

Google Visで試したいのは一個だけ。それやったら終わり。

コメント

タイトルとURLをコピーしました