プログラミング/julia/gist との連携
nbextensions の導入†
http://jupyter-contrib-nbextensions.readthedocs.io/en/latest/install.html
LANG:console $ sudo python3 -m pip install jupyter_contrib_nbextensions $ jupyter contrib nbextension install --user
とすると、jupyter notebook にて Nbextentions というタブを開けるようになる。
Gist との連携†
http://jupyter-contrib-nbextensions.readthedocs.io/en/latest/nbextensions/gist_it/readme.html
- github へログインした後、https://github.com/settings/tokens の "Generate a personal access token" リンクをクリック
- Token description に "jupyter notebook" など分かりやすい説明を付ける
- "□ gist | Create gists" をチェック
- "Generate Token" をクリック
- Token をコピー
- jupyter notebook の Nbextentions タブで Gist-it にチェックを付ける
- gist-it をクリックして現れる "Github personal access token" フィールドに Token を貼り付ける
これで、適当な notebook を開くと、Gist it ボタンが現れる。
ボタンを押して description を記入し、Gist it! を押す。
あれ?ajax エラーが出たぞ???
Chrome の デベロッパーツールで見てみると、api.github.com へ向けた通信のステータスが (canceled) となっていた。
コンソールには github ajax error が表示されて、status が 404 になっていた?!
実際にアクセスしてエラーになる場合には (canceled) にならないので、 実際の通信が行われる前にエラーになっているみたい。
画面に表示されるエラーメッセージ "The ajax request to Github went wrong:" で検索しても黒木さんの https://mathtod.online/@genkuroki/347159 が引っかかるだけっていうのは非常に謎だ。
よほど珍しいことになってる???
Firefox で同じ事をやったら、
「ネットワーク」のところに api.github.com との通信履歴が生じなかった。 やはり実際の通信が生じる前にエラーになっている。
そして、
<script> 要素の ‘src’ 属性が正しい URI ではありません: “https://api.github.com/gists?{"files":{"test-plotly.ipynb":{"content":"{\n \"cells\": [\n {\n \"metadata\": {},\n \"cell_type\": \"markdown\",\n \"source\": \"# plotly利用のテスト\"\n },\n {\n \"metadata\": {},\n \"cell_type\": \"markdown\",\n \"source\": \"データを作成\"\n },\n {\n \"metadata\": {\n \"trusted\": true\n },\n \"cell_type\": \"code\",\n \"source\": \"import numpy as np\\ndata_x = np.linspace(0, 100, 10)\\ndata_ys = np.random.random(size=(3, len(data_x)))\\nlabels = ['hoge', 'fuga', 'piyo']\",\n \"execution_count\": 6,\n \"outputs\": []\n },\n {\n \"metadata\": {},\n \"cell_type\": \"markdown\",\n \"source\": \"グラフ表示のおまじない\"\n },\n {\n \"metadata\": {\n \"trusted\": true,\n \"scrolled\": true\n },\n \"cell_type\": \"code\",\n \"source\": \"import plotly.offline as po\\nimport plotly.graph_objs as go\\np…
というエラーも表示された。
何のことだか分からないけど、なぜか post ではなく get でアクセスしに行ってる感じ?
gists の api はこう:https://developer.github.com/v3/gists/
当然、新しい記事を投稿するには post を使う。
でも、https://github.com/ipython-contrib/jupyter_contrib_nbextensions/blob/6af8e5e84e4746476c5b476b7e38f63d7abb2064/src/jupyter_contrib_nbextensions/nbextensions/gist_it/main.js#L444 を見る限り get でアクセスするわけはないんだよなあ・・・
たぶん、ディベロッパーツールの見方が悪いだけだ。
上記のファイルは ~/.local/share/jupyter/nbextensions/gist_it/main.js にあるので、 $ajax の前に次のデバッグ用のコードを追加した。
LANG:console $ jed ~/.local/share/jupyter/nbextensions/gist_it/main.js + console.log({ + url: 'https://api.github.com/gists' + (id ? '/' + id : ''), + type: method, + dataType: 'json', + data: JSON.stringify(data), + beforeSend: add_auth_token, + success: gist_success, + error: gist_error, + complete: complete_callback + });
結果は、
Object { url: "https://api.github.com/gists", type: "POST", dataType: "json", data: "{\"files\":{\"test-plotly.ipynb\":{\"content\":\"{\\n \\\"cells\\\": [\\n {\\n \\\"metadata\\\": {},\\n \\\"cell_type\\\": \\\"markdown\\\",\\n \\\"source\\\": \\\"# jupyterからplotlyを利用する(python)\\\"\\n },\\n {\\n \\\"metadata\\\": {},\\n \\\"cell_type\\\": \\\"markdown\\\",\\n \\\"source\\\": \\\"https://qiita.com/deaikei/items/b71c1ca2c4c2a2c37526 を元に試す\\\\n\\\\nまずデータを作成\\\"\\n },\\n {\\n \\\"metadata\\\": {\\n \\\"trusted\\\": true\\n },\\n \\\"cell_type\\\": \\\"code\\\",\\n \\\"source\\\": \\\"import numpy as np\\\\ndata_x = np.linspace(0, 100, 10)\\\\ndata_ys = np.random.random(size=(3, len(data_x)))\\\\nlabels = ['hoge', 'fuga', 'piyo']\\\",\\n \\\"execution_count\\\": 6,\\n \\\"outputs\\\": []\\n },\\n {\\n \\\"metadata\\\": {},\\n \\\"cell_type\\\": \\\"markdown\\\",\\n \\\"source\\\": \\\"グラフ表示のおまじない\\\"\\n },\\n {\\n \\\"metadata\\\": {\\n \\\"scrolled\\\": true,\\n \\\"trusted\\\": true\\n },\\n \\\"cell_type\\\": \\\"code\\\",\\n \\\"source\\\": \\\"import plotly.offline as po\\\\nimport plotly.graph_o…", beforeSend: add_auth_token(), success: gist_success(), error: gist_error(), complete: click() }
data の中味は
{ description: "jupyterからplotlyを利用する(python)", files: { "test-plotly.ipynb": Object { content: "{\n \"cells\": [\n ..." } }, public: false }
となっていて、特に問題なさそうに見える。
でも gist_error で次のエラーが表示される。
jqXHR = { ... readyState: 4 status: 404 statusText: "error" }
status = 404 は Not Found で、通信もしていないのにこのエラーが出るのはおかしいなあ。。。
黒木さんに教えていただき juliabox で試してみた†
困ったなー、とつぶやいたところ、なんと黒木さんからメッセージを頂いてしまった。
ということで、juliabox でやってみたところ、
何の問題も無くできてしまった。
ふむ。
アクセスは https://api.github.com/gists への POST で、 要求ヘッダーは
Accept: "application/json, text/javascript, */*; q=0.01" Accept-Encoding: "gzip, deflate, br" Accept-Language: "ja,en-US;q=0.7,en;q=0.3" Authorization: "token xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" Connection: "keep-alive" Content-Length: 1329 Content-Type: "application/x-www-form-urlencoded; charset=UTF-8" Host: "api.github.com" Origin: "https://juliabox.com" Referer: "https://juliabox.com/notebook/notebooks/hello-juliabox.ipynb" User-Agent: "Mozilla/5.0 (Windows NT 10.0; …) Gecko/20100101 Firefox/59.0"
body は、
{ "files": { "hello-juliabox.ipynb": { "content": "{\n \"cells\": [\n {\n \"metadata\": {\n \"trusted\": true\n }, ..." } }, "description": "julia hello", "public":true }
なので、特に変わったところはない。
ファイルが大きすぎたらしい?†
先に試した notebook は plotly を含んでいたため、 実はあれだけでファイルサイズが 5メガバイト もあった。
Hello world だけで試したら何の問題も無かった。
でも黒木さんによると、
とのことで、ファイルサイズの問題ではないらしい。
とりあえず進めて、本当に使いたいファイルでエラーが出たらまた詳しく条件を探ろうと思う。