denomagic


Namedenomagic JSON
Version 1.0.1 PyPI version JSON
download
home_pageNone
SummaryPython package to run JavaScript/TypeScript(Deno backend) in Jupyter notebooks and Google Colab.
upload_time2024-06-09 09:05:06
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)を書いて実行するためのマジックコマンドです。

## 使い方

### インストール

Jupyter環境ではあらかじめDenoをインストールしてパスを通しておく必要があります。インストール方法は[Denoの公式サイト](https://deno.com/)を参照してください。VSCode経由でJupyter(拡張機能)を使う場合はさらにDeno拡張機能をインストールしたうえで設定でDeno.enableをtrueにしてください。

Google Colab環境ではパッケージにインストール用の関数が用意されているので個別にインストールする必要はありません。

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

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

```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

コードセル内のJavaScript/TypeScriptをDenoで実行します。
引数はありません。

#### %%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/2b/53/9979b5267eb13167fed9955bacfa1c1ce97c9331b95ffb1af0eddec10f9b/denomagic-1.0.1.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### \u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\r\n\r\nJupyter\u74b0\u5883\u3067\u306f\u3042\u3089\u304b\u3058\u3081Deno\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u30d1\u30b9\u3092\u901a\u3057\u3066\u304a\u304f\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u65b9\u6cd5\u306f[Deno\u306e\u516c\u5f0f\u30b5\u30a4\u30c8](https://deno.com/)\u3092\u53c2\u7167\u3057\u3066\u304f\u3060\u3055\u3044\u3002VSCode\u7d4c\u7531\u3067Jupyter(\u62e1\u5f35\u6a5f\u80fd)\u3092\u4f7f\u3046\u5834\u5408\u306f\u3055\u3089\u306bDeno\u62e1\u5f35\u6a5f\u80fd\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u305f\u3046\u3048\u3067\u8a2d\u5b9a\u3067Deno.enable\u3092true\u306b\u3057\u3066\u304f\u3060\u3055\u3044\u3002\r\n\r\nGoogle Colab\u74b0\u5883\u3067\u306f\u30d1\u30c3\u30b1\u30fc\u30b8\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u7528\u306e\u95a2\u6570\u304c\u7528\u610f\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u500b\u5225\u306b\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u5fc5\u8981\u306f\u3042\u308a\u307e\u305b\u3093\u3002\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\u547c\u3073\u51fa\u3057\u3066\u3082\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u305b\u3093)\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\u30b3\u30fc\u30c9\u30bb\u30eb\u5185\u306eJavaScript/TypeScript\u3092Deno\u3067\u5b9f\u884c\u3057\u307e\u3059\u3002\r\n\u5f15\u6570\u306f\u3042\u308a\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.0.1",
    "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": "485313204f76f93c8ac565b6f26b71b6fb89f1e8006dea219cff3aaf077879b9",
                "md5": "039e36b7fb6e165993d4ee43894cf3d5",
                "sha256": "d21c1186e13fa3f55d3cab226f41706b981ccc47c38f1635fe19a50089bbad81"
            },
            "downloads": -1,
            "filename": "denomagic-1.0.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "039e36b7fb6e165993d4ee43894cf3d5",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 5373,
            "upload_time": "2024-06-09T09:05:02",
            "upload_time_iso_8601": "2024-06-09T09:05:02.960684Z",
            "url": "https://files.pythonhosted.org/packages/48/53/13204f76f93c8ac565b6f26b71b6fb89f1e8006dea219cff3aaf077879b9/denomagic-1.0.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "2b539979b5267eb13167fed9955bacfa1c1ce97c9331b95ffb1af0eddec10f9b",
                "md5": "c2e0dcae0388c22d6e43034bc26d12d6",
                "sha256": "d79666372a0cd85b62cd2ad814465ff8be91bca8a84fcc77bc791e7ea1245237"
            },
            "downloads": -1,
            "filename": "denomagic-1.0.1.tar.gz",
            "has_sig": false,
            "md5_digest": "c2e0dcae0388c22d6e43034bc26d12d6",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 5052,
            "upload_time": "2024-06-09T09:05:06",
            "upload_time_iso_8601": "2024-06-09T09:05:06.233081Z",
            "url": "https://files.pythonhosted.org/packages/2b/53/9979b5267eb13167fed9955bacfa1c1ce97c9331b95ffb1af0eddec10f9b/denomagic-1.0.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-06-09 09:05:06",
    "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.25396s