クソ記事を量産中です。
必要となる知識や準備等
必要となる知識
- いろんあグラフが使えるGoogle Visualization API
- Google Visualization APIは基本 JavaScript で使います
- pythonで試みるとはいえ、実質Jsonを用意するだけ
- なんかJson用意すればとりあえずそれが使えるっぽい
- ネット接続が必須
Google Visは多機能っぽいのに、ネットが必須ってのではっきり萎えました。やる気0です。でも試す価値はあるかもしれません。
pythonとGoogle Visを連載させるための準備
Anaconda Promptで以下。
pip install gviz_api
はっきりいってたぶんpythonいらん。javascriptだけでいい。でもそれでもやりたいって人はどうぞ。
- 参考_1: 【旧版】Google Chart Tools入門 (全12回) – プログラミングならドットインストール
- 参考_2: Data Source Python Library | Charts | Google Developers
- 参考_3: Data Queries | Charts | Google Developers
- 参考_4: GitHub – google/google-visualization-python: Automatically exported from code.google.com/p/google-visualization-python
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()
結果
なんでネット環境がないとだめなの?オフラインでも使えるようにしてよグーグル。
雑感
だるい。
Google Visで試したいのは一個だけ。それやったら終わり。
コメント