denomagic


Namedenomagic JSON
Version 1.1.0 PyPI version JSON
download
home_pageNone
SummaryPython package to run JavaScript/TypeScript(Deno backend) in Jupyter notebooks and Google Colab.
upload_time2024-06-29 00:49:29
maintainerNone
docs_urlNone
authorUniras
requires_pythonNone
licenseMIT License
keywords deno jupyter magic
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Deno Magic Command

## 概要

Jypyter(notebook/lab)またはGoogle ColabのコードセルにDeno(JavaScript/TypeScript)を書いて実行するためのマジックコマンドです。

## 使い方

### マジックコマンドの追加

コードセルに以下のコードを貼り付けて実行しマジックコマンドを登録してください。カーネルやランタイムを再起動する度に再実行する必要があります。

```python
%pip install denomagic
import denomagic

# denoのインストール(Google Colab用、他の環境では無視されます
denomagic.install_deno_colab()
# マジックコマンドの登録
denomagic.register_deno_magics()
```

### マジックコマンドの使い方

コードセルの冒頭に以下のようにマジックコマンドを記述してください。実行するとDenoによってコードセル内のJavaScript/TypeScriptコードが実行されます。

```javascript
%%run_deno

console.log("Hello, world!");
```

また、コードセルのJavaScript/TypeScriptコードをDenoでトランスパイルしてiframe内で実行するマジックコマンドも用意しています。
以下は、ブラウザ用のライブラリであるp5.jsを使った例です。

```javascript
%%run_deno_iframe 830 430
import "https://cdn.jsdelivr.net/npm/p5@1.9.4/lib/p5.js";

const sketch = (p: any) => {
  let x = 0;
  let y = 0;
  let speed = 2;
  let color: [number, number, number] = [0, 0, 0];

  p.setup = () => {
    p.createCanvas(800, 400);
    x = p.width / 2;
    y = p.height / 2;
  };

  p.draw = () => {
    p.background(220);
    p.fill(color);
    p.ellipse(x, y, 50, 50);
    if (p.keyIsDown(p.LEFT_ARROW) === true) {
      x -= speed;
    }

    if (p.keyIsDown(p.RIGHT_ARROW) === true) {
      x += speed;
    }

    if (p.keyIsDown(p.UP_ARROW) === true) {
      y -= speed;
    }

    if (p.keyIsDown(p.DOWN_ARROW) === true) {
      y += speed;
    }
  };

  p.mousePressed = () => {
    color = [p.random(255), p.random(255), p.random(255)];
  };
};

new p5(sketch);
```

### マジックコマンド

#### %%run_deno

```jupyter
%%run_deno [userval]
```

コードセル内のJavaScript/TypeScriptをDenoで実行します。

- userval: Jupyterのユーザー変数をDenoで利用するかどうかを設定します。デフォルトはFalseです。

usevalをTrueにすると、Jupyterのユーザー変数を`globalThis.jupyter`を通じて利用できるようになり、セルを超えた変数のやりとりが出来るようになります。  
内部ではJupyterとDenoの間をJSONの一時ファイルでやりとりしているため、JSONに変換できないオブジェクトは利用できません。  
利用した場合の動作は未定義です。

Jupyterのコードセル内で実行されている場合、`globalThis.isJupyterCell`が定義されているので、これが`undefined`ではないかどうかを確認することでJupyterのコードセルからの実行なのかどうかを判定できます。

Jupyterユーザー変数を利用した状態でコードセルの途中で終了させたい場合はDeno.exitの代わりに`jupyterExit()`を利用してください。
Deno.exitで終了するとJupyterのユーザー変数は更新されません。

#### %%run_deno_iframe

コードセル内のJavaScript/TypeScriptをDenoでトランスパイルしてiframe内で実行します。

```jupyter
%%run_deno_iframe [width] [height] [srcs]
```

- width: iframeの幅を指定します。デフォルトは500です。
- height: iframeの高さを指定します。デフォルトは500です。
- srcs: 外部JavaScriptのURLを指定します。複数指定する場合はスペースで区切ります。

#### %%run_deno_bundle_iframe

コードセル内のJavaScript/TypeScriptをimportしたコードも含めてトランスパイル及びバンドルしてiframe内で実行します。

引数は%%run_deno_iframeと同じです。

#### %%view_deno_iframe

コードセル内のJavaScript/TypeScriptをDenoでトランスパイルした後生成したHTMLを出力します。

引数は%%run_deno_iframeと同じです。

#### %%view_deno_bundle_iframe

コードセル内のJavaScript/TypeScriptをimportしたコードも含めてトランスパイル及びバンドルした後生成したHTMLを出力します。

引数は%%run_deno_iframeと同じです。

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "denomagic",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "deno, jupyter, magic",
    "author": "Uniras",
    "author_email": "tkappeng@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/9b/2b/aa0e85f969aee87b92b8609e517ff0b9c8084ab73dc2e2c40aa8d896f03d/denomagic-1.1.0.tar.gz",
    "platform": null,
    "description": "# Deno Magic Command\r\n\r\n## \u6982\u8981\r\n\r\nJypyter(notebook/lab)\u307e\u305f\u306fGoogle Colab\u306e\u30b3\u30fc\u30c9\u30bb\u30eb\u306bDeno(JavaScript/TypeScript)\u3092\u66f8\u3044\u3066\u5b9f\u884c\u3059\u308b\u305f\u3081\u306e\u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u3067\u3059\u3002\r\n\r\n## \u4f7f\u3044\u65b9\r\n\r\n### \u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u306e\u8ffd\u52a0\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u306b\u4ee5\u4e0b\u306e\u30b3\u30fc\u30c9\u3092\u8cbc\u308a\u4ed8\u3051\u3066\u5b9f\u884c\u3057\u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u3092\u767b\u9332\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u30ab\u30fc\u30cd\u30eb\u3084\u30e9\u30f3\u30bf\u30a4\u30e0\u3092\u518d\u8d77\u52d5\u3059\u308b\u5ea6\u306b\u518d\u5b9f\u884c\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\r\n\r\n```python\r\n%pip install denomagic\r\nimport denomagic\r\n\r\n# deno\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb(Google Colab\u7528\u3001\u4ed6\u306e\u74b0\u5883\u3067\u306f\u7121\u8996\u3055\u308c\u307e\u3059\r\ndenomagic.install_deno_colab()\r\n# \u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u306e\u767b\u9332\r\ndenomagic.register_deno_magics()\r\n```\r\n\r\n### \u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u306e\u4f7f\u3044\u65b9\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u306e\u5192\u982d\u306b\u4ee5\u4e0b\u306e\u3088\u3046\u306b\u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u3092\u8a18\u8ff0\u3057\u3066\u304f\u3060\u3055\u3044\u3002\u5b9f\u884c\u3059\u308b\u3068Deno\u306b\u3088\u3063\u3066\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u30b3\u30fc\u30c9\u304c\u5b9f\u884c\u3055\u308c\u307e\u3059\u3002\r\n\r\n```javascript\r\n%%run_deno\r\n\r\nconsole.log(\"Hello, world!\");\r\n```\r\n\r\n\u307e\u305f\u3001\u30b3\u30fc\u30c9\u30bb\u30eb\u306eJavaScript/TypeScript\u30b3\u30fc\u30c9\u3092Deno\u3067\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u3057\u3066iframe\u5185\u3067\u5b9f\u884c\u3059\u308b\u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\u3082\u7528\u610f\u3057\u3066\u3044\u307e\u3059\u3002\r\n\u4ee5\u4e0b\u306f\u3001\u30d6\u30e9\u30a6\u30b6\u7528\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3042\u308bp5.js\u3092\u4f7f\u3063\u305f\u4f8b\u3067\u3059\u3002\r\n\r\n```javascript\r\n%%run_deno_iframe 830 430\r\nimport \"https://cdn.jsdelivr.net/npm/p5@1.9.4/lib/p5.js\";\r\n\r\nconst sketch = (p: any) => {\r\n  let x = 0;\r\n  let y = 0;\r\n  let speed = 2;\r\n  let color: [number, number, number] = [0, 0, 0];\r\n\r\n  p.setup = () => {\r\n    p.createCanvas(800, 400);\r\n    x = p.width / 2;\r\n    y = p.height / 2;\r\n  };\r\n\r\n  p.draw = () => {\r\n    p.background(220);\r\n    p.fill(color);\r\n    p.ellipse(x, y, 50, 50);\r\n    if (p.keyIsDown(p.LEFT_ARROW) === true) {\r\n      x -= speed;\r\n    }\r\n\r\n    if (p.keyIsDown(p.RIGHT_ARROW) === true) {\r\n      x += speed;\r\n    }\r\n\r\n    if (p.keyIsDown(p.UP_ARROW) === true) {\r\n      y -= speed;\r\n    }\r\n\r\n    if (p.keyIsDown(p.DOWN_ARROW) === true) {\r\n      y += speed;\r\n    }\r\n  };\r\n\r\n  p.mousePressed = () => {\r\n    color = [p.random(255), p.random(255), p.random(255)];\r\n  };\r\n};\r\n\r\nnew p5(sketch);\r\n```\r\n\r\n### \u30de\u30b8\u30c3\u30af\u30b3\u30de\u30f3\u30c9\r\n\r\n#### %%run_deno\r\n\r\n```jupyter\r\n%%run_deno [userval]\r\n```\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u3092Deno\u3067\u5b9f\u884c\u3057\u307e\u3059\u3002\r\n\r\n- userval: Jupyter\u306e\u30e6\u30fc\u30b6\u30fc\u5909\u6570\u3092Deno\u3067\u5229\u7528\u3059\u308b\u304b\u3069\u3046\u304b\u3092\u8a2d\u5b9a\u3057\u307e\u3059\u3002\u30c7\u30d5\u30a9\u30eb\u30c8\u306fFalse\u3067\u3059\u3002\r\n\r\nuseval\u3092True\u306b\u3059\u308b\u3068\u3001Jupyter\u306e\u30e6\u30fc\u30b6\u30fc\u5909\u6570\u3092`globalThis.jupyter`\u3092\u901a\u3058\u3066\u5229\u7528\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u3001\u30bb\u30eb\u3092\u8d85\u3048\u305f\u5909\u6570\u306e\u3084\u308a\u3068\u308a\u304c\u51fa\u6765\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002  \r\n\u5185\u90e8\u3067\u306fJupyter\u3068Deno\u306e\u9593\u3092JSON\u306e\u4e00\u6642\u30d5\u30a1\u30a4\u30eb\u3067\u3084\u308a\u3068\u308a\u3057\u3066\u3044\u308b\u305f\u3081\u3001JSON\u306b\u5909\u63db\u3067\u304d\u306a\u3044\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306f\u5229\u7528\u3067\u304d\u307e\u305b\u3093\u3002  \r\n\u5229\u7528\u3057\u305f\u5834\u5408\u306e\u52d5\u4f5c\u306f\u672a\u5b9a\u7fa9\u3067\u3059\u3002\r\n\r\nJupyter\u306e\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u3067\u5b9f\u884c\u3055\u308c\u3066\u3044\u308b\u5834\u5408\u3001`globalThis.isJupyterCell`\u304c\u5b9a\u7fa9\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3001\u3053\u308c\u304c`undefined`\u3067\u306f\u306a\u3044\u304b\u3069\u3046\u304b\u3092\u78ba\u8a8d\u3059\u308b\u3053\u3068\u3067Jupyter\u306e\u30b3\u30fc\u30c9\u30bb\u30eb\u304b\u3089\u306e\u5b9f\u884c\u306a\u306e\u304b\u3069\u3046\u304b\u3092\u5224\u5b9a\u3067\u304d\u307e\u3059\u3002\r\n\r\nJupyter\u30e6\u30fc\u30b6\u30fc\u5909\u6570\u3092\u5229\u7528\u3057\u305f\u72b6\u614b\u3067\u30b3\u30fc\u30c9\u30bb\u30eb\u306e\u9014\u4e2d\u3067\u7d42\u4e86\u3055\u305b\u305f\u3044\u5834\u5408\u306fDeno.exit\u306e\u4ee3\u308f\u308a\u306b`jupyterExit()`\u3092\u5229\u7528\u3057\u3066\u304f\u3060\u3055\u3044\u3002\r\nDeno.exit\u3067\u7d42\u4e86\u3059\u308b\u3068Jupyter\u306e\u30e6\u30fc\u30b6\u30fc\u5909\u6570\u306f\u66f4\u65b0\u3055\u308c\u307e\u305b\u3093\u3002\r\n\r\n#### %%run_deno_iframe\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u3092Deno\u3067\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u3057\u3066iframe\u5185\u3067\u5b9f\u884c\u3057\u307e\u3059\u3002\r\n\r\n```jupyter\r\n%%run_deno_iframe [width] [height] [srcs]\r\n```\r\n\r\n- width: iframe\u306e\u5e45\u3092\u6307\u5b9a\u3057\u307e\u3059\u3002\u30c7\u30d5\u30a9\u30eb\u30c8\u306f500\u3067\u3059\u3002\r\n- height: iframe\u306e\u9ad8\u3055\u3092\u6307\u5b9a\u3057\u307e\u3059\u3002\u30c7\u30d5\u30a9\u30eb\u30c8\u306f500\u3067\u3059\u3002\r\n- srcs: \u5916\u90e8JavaScript\u306eURL\u3092\u6307\u5b9a\u3057\u307e\u3059\u3002\u8907\u6570\u6307\u5b9a\u3059\u308b\u5834\u5408\u306f\u30b9\u30da\u30fc\u30b9\u3067\u533a\u5207\u308a\u307e\u3059\u3002\r\n\r\n#### %%run_deno_bundle_iframe\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u3092import\u3057\u305f\u30b3\u30fc\u30c9\u3082\u542b\u3081\u3066\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u53ca\u3073\u30d0\u30f3\u30c9\u30eb\u3057\u3066iframe\u5185\u3067\u5b9f\u884c\u3057\u307e\u3059\u3002\r\n\r\n\u5f15\u6570\u306f%%run_deno_iframe\u3068\u540c\u3058\u3067\u3059\u3002\r\n\r\n#### %%view_deno_iframe\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u3092Deno\u3067\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u3057\u305f\u5f8c\u751f\u6210\u3057\u305fHTML\u3092\u51fa\u529b\u3057\u307e\u3059\u3002\r\n\r\n\u5f15\u6570\u306f%%run_deno_iframe\u3068\u540c\u3058\u3067\u3059\u3002\r\n\r\n#### %%view_deno_bundle_iframe\r\n\r\n\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u3092import\u3057\u305f\u30b3\u30fc\u30c9\u3082\u542b\u3081\u3066\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u53ca\u3073\u30d0\u30f3\u30c9\u30eb\u3057\u305f\u5f8c\u751f\u6210\u3057\u305fHTML\u3092\u51fa\u529b\u3057\u307e\u3059\u3002\r\n\r\n\u5f15\u6570\u306f%%run_deno_iframe\u3068\u540c\u3058\u3067\u3059\u3002\r\n",
    "bugtrack_url": null,
    "license": "MIT License",
    "summary": "Python package to run JavaScript/TypeScript(Deno backend) in Jupyter notebooks and Google Colab.",
    "version": "1.1.0",
    "project_urls": {
        "Homepage": "https://github.com/uniras/DenoMagic",
        "Repository": "https://github.com/uniras/DenoMagic"
    },
    "split_keywords": [
        "deno",
        " jupyter",
        " magic"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "d40c2edab808c4ba4d83e1d51a883da775d939703819244be3fbbcd47e9312ad",
                "md5": "fcdecb29428c250cb303c1cec70e7a57",
                "sha256": "8ee84fdf4fcb8a96b56d4da022725dcb297545ae6fc19ea773306d2b342aeb79"
            },
            "downloads": -1,
            "filename": "denomagic-1.1.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "fcdecb29428c250cb303c1cec70e7a57",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 6298,
            "upload_time": "2024-06-29T00:49:27",
            "upload_time_iso_8601": "2024-06-29T00:49:27.747902Z",
            "url": "https://files.pythonhosted.org/packages/d4/0c/2edab808c4ba4d83e1d51a883da775d939703819244be3fbbcd47e9312ad/denomagic-1.1.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "9b2baa0e85f969aee87b92b8609e517ff0b9c8084ab73dc2e2c40aa8d896f03d",
                "md5": "ff3dd05881efc2bc387ab531b4e59516",
                "sha256": "a6bdfb274a40143cf404898da22ffc97a57b4a260b88234d621924a9dde6169d"
            },
            "downloads": -1,
            "filename": "denomagic-1.1.0.tar.gz",
            "has_sig": false,
            "md5_digest": "ff3dd05881efc2bc387ab531b4e59516",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 5951,
            "upload_time": "2024-06-29T00:49:29",
            "upload_time_iso_8601": "2024-06-29T00:49:29.711464Z",
            "url": "https://files.pythonhosted.org/packages/9b/2b/aa0e85f969aee87b92b8609e517ff0b9c8084ab73dc2e2c40aa8d896f03d/denomagic-1.1.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-06-29 00:49:29",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "uniras",
    "github_project": "DenoMagic",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "denomagic"
}
        
Elapsed time: 0.29514s