{"id":15036572,"url":"https://github.com/kanaries/pygwalker","last_synced_at":"2025-09-09T21:05:12.307Z","repository":{"id":65949989,"uuid":"602389947","full_name":"Kanaries/pygwalker","owner":"Kanaries","description":"PyGWalker: Turn your pandas dataframe into an interactive UI for visual analysis","archived":false,"fork":false,"pushed_at":"2025-05-02T07:00:28.000Z","size":65586,"stargazers_count":14766,"open_issues_count":65,"forks_count":789,"subscribers_count":89,"default_branch":"main","last_synced_at":"2025-05-05T20:45:33.730Z","etag":null,"topics":["data-analysis","data-exploration","dataframe","matplotlib","pandas","plotly","tableau","tableau-alternative","visualization"],"latest_commit_sha":null,"homepage":"https://kanaries.net/pygwalker","language":"Python","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"apache-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Kanaries.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":"docs/CONTRIBUTING.md","funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2023-02-16T05:17:24.000Z","updated_at":"2025-05-05T14:00:50.000Z","dependencies_parsed_at":"2023-09-23T01:11:23.749Z","dependency_job_id":"33bb8fcd-d458-4350-8919-07dc1d16a987","html_url":"https://github.com/Kanaries/pygwalker","commit_stats":null,"previous_names":[],"tags_count":76,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Kanaries%2Fpygwalker","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Kanaries%2Fpygwalker/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Kanaries%2Fpygwalker/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Kanaries%2Fpygwalker/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Kanaries","download_url":"https://codeload.github.com/Kanaries/pygwalker/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":253929354,"owners_count":21985802,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["data-analysis","data-exploration","dataframe","matplotlib","pandas","plotly","tableau","tableau-alternative","visualization"],"created_at":"2024-09-24T20:31:35.707Z","updated_at":"2025-09-09T21:05:12.264Z","avatar_url":"https://github.com/Kanaries.png","language":"Python","readme":"[English](README.md) | [Español](./docs/README.es.md) | [Français](./docs/README.fr.md) | [Deutsch](./docs/README.de.md) | [中文](./docs/README.zh.md) | [Türkçe](./docs/README.tr.md) | [日本語](./docs/README.ja.md) | [한국어](./docs/README.ko.md) | [Русский](./docs/README.ru.md)\n\n\n\u003cp align=\"center\"\u003e\u003ca href=\"https://github.com/Kanaries/pygwalker\"\u003e\u003cimg width=100% alt=\"\" src=\"https://github.com/user-attachments/assets/f90db669-6e5a-45d3-942e-547c9d0471c9\" /\u003e\u003c/a\u003e\u003c/p\u003e\n\n\u003ch2 align=\"center\"\u003ePyGWalker: A Python Library for Exploratory Data Analysis with Visualization\u003c/h2\u003e\n\n\u003cp align=\"center\"\u003e\n    \u003ca href=\"https://arxiv.org/abs/2406.11637\"\u003e\n      \u003cimg src=\"https://img.shields.io/badge/arXiv-2406.11637-b31b1b.svg\" height=\"18\" align=\"center\"\u003e\n    \u003c/a\u003e\n    \u003ca href=\"https://badge.fury.io/py/pygwalker\"\u003e\n        \u003cimg src=\"https://badge.fury.io/py/pygwalker.svg\" alt=\"PyPI version\" height=\"18\" align=\"center\" /\u003e\n    \u003c/a\u003e\n    \u003ca href=\"https://mybinder.org/v2/gh/Kanaries/pygwalker/main\"\u003e\n      \u003cimg src=\"https://mybinder.org/badge_logo.svg\" alt=\"binder\" height=\"18\" align=\"center\" /\u003e\n    \u003c/a\u003e\n    \u003ca href=\"https://pypi.org/project/pygwalker\"\u003e\n      \u003cimg src=\"https://img.shields.io/pypi/dm/pygwalker\" alt=\"PyPI downloads\" height=\"18\" align=\"center\" /\u003e\n    \u003c/a\u003e\n    \u003ca href=\"https://anaconda.org/conda-forge/pygwalker\"\u003e \u003cimg src=\"https://anaconda.org/conda-forge/pygwalker/badges/version.svg\" alt=\"conda-forge\" height=\"18\" align=\"center\" /\u003e \u003c/a\u003e\n\u003c/p\u003e\n\n\u003cp align=\"center\"\u003e\n    \u003ca href=\"https://discord.gg/Z4ngFWXz2U\"\u003e\n      \u003cimg alt=\"discord invitation link\" src=\"https://dcbadge.vercel.app/api/server/Z4ngFWXz2U?style=flat\" align=\"center\" /\u003e\n    \u003c/a\u003e\n    \u003ca href='https://twitter.com/intent/follow?original_referer=https%3A%2F%2Fpublish.twitter.com%2F\u0026ref_src=twsrc%5Etfw\u0026screen_name=kanaries_data\u0026tw_p=followbutton'\u003e\n        \u003cimg alt=\"Twitter Follow\" src=\"https://img.shields.io/twitter/follow/kanaries_data?style=social\" alt='Twitter' align=\"center\" /\u003e\n    \u003c/a\u003e\n    \u003ca href=\"https://kanaries-community.slack.com/join/shared_invite/zt-20kpp56wl-ke9S0MxTcNQjUhKf6SOfvQ#/shared-invite/email\"\u003e\n      \u003cimg src=\"https://img.shields.io/badge/Slack-green?style=flat-square\u0026logo=slack\u0026logoColor=white\" alt=\"Join Kanaries on Slack\" align=\"center\" /\u003e\n    \u003c/a\u003e \n\u003c/p\u003e\n\n[**PyGWalker**](https://github.com/Kanaries/pygwalker) can simplify your Jupyter Notebook data analysis and data visualization workflow, by turning your pandas dataframe into an interactive user interface for visual exploration.\n\n**PyGWalker** (pronounced like \"Pig Walker\", just for fun) is named as an abbreviation of \"**Py**thon binding of **G**raphic **Walker**\". It integrates Jupyter Notebook with [Graphic Walker](https://github.com/Kanaries/graphic-walker), an open-source alternative to Tableau. It allows data scientists to visualize / clean / annotates the data with simple drag-and-drop operations and even natural language queries.\n     \n\nhttps://github.com/Kanaries/pygwalker/assets/22167673/2b940e11-cf8b-4cde-b7f6-190fb10ee44b\n\n\u003e [!TIP]\n\u003e If you want more AI features, we also build [runcell](https://runcell.dev), an AI Code Agent in Jupyter that understands your code/data/cells and generate code, execute cells and take actions for you. It can be used in jupyter lab with `pip install runcell`\n\n\n\nhttps://github.com/user-attachments/assets/9ec64252-864d-4bd1-8755-83f9b0396d38\n\n\n\n\nVisit [Google Colab](https://colab.research.google.com/drive/171QUQeq-uTLgSj1u-P9DQig7Md1kpXQ2?usp=sharing), [Kaggle Code](https://www.kaggle.com/code/lxy21495892/airbnb-eda-pygwalker-demo) or [Graphic Walker Online Demo](https://graphic-walker.kanaries.net/) to test it out!\n\n\u003e If you prefer using R, check [GWalkR](https://github.com/Kanaries/GWalkR), the R wrapper of Graphic Walker.\n\u003e If you prefer a Desktop App that can be used offline and without any coding, check out [PyGWalker Desktop](https://kanaries.net/download?utm_source=pygwalker_github\u0026utm_content=tip).\n\n\n# Features\nPyGWalker is a Python library that simplifies data analysis and visualization workflows by turning pandas DataFrames into interactive visual interfaces.\nIt offers a variety of features that make it a powerful tool for data exploration:\n- ##### Interactive Data Exploration:\n    - Drag-and-drop interface for easy visualization creation.   \n    - Real-time updates as you make changes to the visualization.\n    - Ability to zoom, pan, and filter the data.   \n- ##### Data Cleaning and Transformation:\n    - Visual data cleaning tools to identify and remove outliers or inconsistencies.   \n    - Ability to create new variables and features based on existing data.   \n- ##### Advanced Visualization Capabilities:\n    - Support for various chart types (bar charts, line charts, scatter plots, etc.). \n    - Customization options for colors, labels, and other visual elements.   \n    - Interactive features like tooltips and drill-down capabilities.   \n- ##### Integration with Jupyter Notebooks:\n    - Seamless integration with Jupyter Notebooks for a smooth workflow.   \n- ##### Open-Source and Free:\n    - Available for free and allows for customization and extension.\n\n\n\n# Getting Started\n\u003e Check our video tutorial about using pygwalker, pygwalker + streamlit and pygwalker + snowflake, [How to explore data with PyGWalker in Python\n](https://youtu.be/rprn79wfB9E?si=lAsJn1cAQnb-EklD)\n\n| [Run in Kaggle](https://www.kaggle.com/code/lxy21495892/airbnb-eda-pygwalker-demo) | [Run in Colab](https://colab.research.google.com/drive/171QUQeq-uTLgSj1u-P9DQig7Md1kpXQ2?usp=sharing) |\n|--------------------------------------------------------------|--------------------------------------------------------|\n| [![Kaggle Code](https://docs-us.oss-us-west-1.aliyuncs.com/img/pygwalker/kaggle.png)](https://www.kaggle.com/code/lxy21495892/airbnb-eda-pygwalker-demo) | [![Google Colab](https://docs-us.oss-us-west-1.aliyuncs.com/img/pygwalker/colab.png)](https://colab.research.google.com/drive/171QUQeq-uTLgSj1u-P9DQig7Md1kpXQ2?usp=sharing) |\n\n## Setup pygwalker\n\nBefore using pygwalker, make sure to install the packages through the command line using pip or conda.\n\n### pip\n\n```bash\npip install pygwalker\n```\n\u003e **Note**\n\u003e \n\u003e For an early trial, you can install with `pip install pygwalker --upgrade` to keep your version up to date with the latest release or even `pip install pygwalker --upgrade --pre` to obtain latest features and bug-fixes.\n\n### Conda-forge\n```bash\nconda install -c conda-forge pygwalker\n```\nor\n```bash\nmamba install -c conda-forge pygwalker\n```\nSee [conda-forge feedstock](https://github.com/conda-forge/pygwalker-feedstock) for more help.\n\n\n## Use pygwalker in Jupyter Notebook\n\n### Quick Start\n\nImport pygwalker and pandas to your Jupyter Notebook to get started.\n\n```python    \nimport pandas as pd\nimport pygwalker as pyg\n```\n\nYou can use pygwalker without breaking your existing workflow. For example, you can call up PyGWalker with the dataframe loaded in this way:\n\n```python\ndf = pd.read_csv('./bike_sharing_dc.csv')\nwalker = pyg.walk(df)\n```\n\n![](https://docs-us.oss-us-west-1.aliyuncs.com/img/pygwalker/travel-ani-0-light.gif)\n\nThat's it. Now you have an interactive UI to analyze and visualize data with simple drag-and-drop operations.\n\n![](https://docs-us.oss-us-west-1.aliyuncs.com/img/pygwalker/travel-ani-1-light.gif)\n\nCool things you can do with PyGwalker:\n\n+ You can change the mark type into others to make different charts, for example, a line chart:\n![graphic walker line chart](https://user-images.githubusercontent.com/8137814/221894699-b9623304-4eb1-4051-b29d-ca4a913fb7c7.png)\n\n+ To compare different measures, you can create a concat view by adding more than one measure into rows/columns.\n![graphic walker area chart](https://user-images.githubusercontent.com/8137814/224550839-7b8a2193-d3e9-4c11-a19e-ad8e5ec19539.png)\n\n+ To make a facet view of several subviews divided by the value in dimension, put dimensions into rows or columns to make a facets view.\n![graphic walker scatter chart](https://user-images.githubusercontent.com/8137814/221894480-b5ec5df2-d0bb-45bc-aa3d-6479920b6fe2.png)\n\n+ PyGWalker contains a powerful data table, which provides a quick view of data and its distribution, profiling. You can also add filters or change the data types in the table.\n\u003cimg width=\"1537\" alt=\"pygwalker-data-preview\" src=\"https://github.com/Kanaries/pygwalker/assets/22167673/e3239932-bc3c-4de3-8387-1eabf2ca3a3a\"\u003e\n\n+ You can save the data exploration result to a local file\n\n### Better Practices\n\nThere are some important parameters you should know when using pygwalker: \n\n+ `spec`: for save/load chart config (json string or file path)\n+ `kernel_computation`: for using duckdb as computing engine which allows you to handle larger dataset faster in your local machine.\n+ `use_kernel_calc`: Deprecated, use `kernel_computation` instead.\n\n```python\ndf = pd.read_csv('./bike_sharing_dc.csv')\nwalker = pyg.walk(\n    df,\n    spec=\"./chart_meta_0.json\",    # this json file will save your chart state, you need to click save button in ui mannual when you finish a chart, 'autosave' will be supported in the future.\n    kernel_computation=True,          # set `kernel_computation=True`, pygwalker will use duckdb as computing engine, it support you explore bigger dataset(\u003c=100GB).\n)\n```\n\n### Example in local notebook\n\n* Notebook Code: [Click Here](https://github.com/Kanaries/pygwalker-offline-example)\n* Preview Notebook Html: [Click Here](https://pygwalker-public-bucket.s3.amazonaws.com/demo.html)\n\n### Example in cloud notebook\n\n* [Use PyGWalker in Kaggle](https://www.kaggle.com/code/lxy21495892/airbnb-eda-pygwalker-demo)\n* [Use PyGWalker in Google Colab](https://colab.research.google.com/drive/171QUQeq-uTLgSj1u-P9DQig7Md1kpXQ2?usp=sharing)\n\n### Programmatic Export of Charts\n\nAfter saving a chart from the UI, you can retrieve the image directly from Python.\n\n```python\nwalker = pyg.walk(df, spec=\"./chart_meta_0.json\")\n# edit the chart in the UI and click the save button\nwalker.save_chart_to_file(\"Chart 1\", \"chart1.svg\", save_type=\"svg\")\npng_bytes = walker.export_chart_png(\"Chart 1\")\nsvg_bytes = walker.export_chart_svg(\"Chart 1\")\n```\n\n## Use pygwalker in Streamlit\nStreamlit allows you to host a web version of pygwalker without figuring out details of how web application works.\n\nHere are some of the app examples build with pygwalker and streamlit:\n+ [PyGWalker + streamlit for Bike sharing dataset](https://pygwalkerdemo-cxz7f7pt5oc.streamlit.app/)\n+ [Earthquake Dashboard](https://earthquake-dashboard-pygwalker.streamlit.app/)\n\n[![](https://user-images.githubusercontent.com/22167673/271170853-5643c3b1-6216-4ade-87f4-41c6e6893eab.png)](https://earthquake-dashboard-pygwalker.streamlit.app/)\n\n```python\nfrom pygwalker.api.streamlit import StreamlitRenderer\nimport pandas as pd\nimport streamlit as st\n\n# Adjust the width of the Streamlit page\nst.set_page_config(\n    page_title=\"Use Pygwalker In Streamlit\",\n    layout=\"wide\"\n)\n\n# Add Title\nst.title(\"Use Pygwalker In Streamlit\")\n\n# You should cache your pygwalker renderer, if you don't want your memory to explode\n@st.cache_resource\ndef get_pyg_renderer() -\u003e \"StreamlitRenderer\":\n    df = pd.read_csv(\"./bike_sharing_dc.csv\")\n    # If you want to use feature of saving chart config, set `spec_io_mode=\"rw\"`\n    return StreamlitRenderer(df, spec=\"./gw_config.json\", spec_io_mode=\"rw\")\n\n\nrenderer = get_pyg_renderer()\n\nrenderer.explorer()\n```\n\n## [API Reference](https://pygwalker-docs.vercel.app/api-reference/jupyter)\n\n### [pygwalker.walk](https://pygwalker-docs.vercel.app/api-reference/jupyter#walk)\n\n\n| Parameter              | Type                                                      | Default              | Description                                                                                                                                      |\n|------------------------|-----------------------------------------------------------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|\n| dataset                | Union[DataFrame, Connector]                               | -                    | The dataframe or connector to be used.                                                                                                           |\n| gid                    | Union[int, str]                                           | None                 | ID for the GraphicWalker container div, formatted as 'gwalker-{gid}'.                                                                            |\n| env                    | Literal['Jupyter', 'JupyterWidget']          | 'JupyterWidget'      | Environment using pygwalker.                                                                                                                     |\n| field_specs             | Optional[Dict[str, FieldSpec]]                            | None                 | Specifications of fields. Will be automatically inferred from `dataset` if not specified.                                                        |\n| hide_data_source_config   | bool                                                      | True                 | If True, hides DataSource import and export button.                                                                                              |\n| theme_key               | Literal['vega', 'g2']                                     | 'g2'                 | Theme type for the GraphicWalker.                                                                                                                |\n| appearance                   | Literal['media', 'light', 'dark']                         | 'media'              | Theme setting. 'media' will auto-detect the OS theme.                                                                                            |\n| spec                   | str                                                       | \"\"                   | Chart configuration data. Can be a configuration ID, JSON, or remote file URL.                                                                   |\n| use_preview            | bool                                                      | True                 | If True, uses the preview function.                                                                                                              |\n| kernel_computation        | bool                                                      | False                | If True, uses kernel computation for data.                                                                                                       |\n| **kwargs               | Any                                                       | -                    | Additional keyword arguments.                                                                                                                    |\n\n## Development\n\nRefer it: [local-development](https://docs.kanaries.net/pygwalker/installation#local-development)\n\n## Tested Environments\n\n- [x] Jupyter Notebook\n- [x] Google Colab\n- [x] Kaggle Code\n- [x] Jupyter Lab\n- [x] Jupyter Lite\n- [x] Databricks Notebook (Since version `0.1.4a0`)\n- [x] Jupyter Extension for Visual Studio Code (Since version `0.1.4a0`)\n- [x] Most web applications compatiable with IPython kernels. (Since version `0.1.4a0`)\n- [x] **Streamlit (Since version `0.1.4.9`)**, enabled with `pyg.walk(df, env='Streamlit')`\n- [x] DataCamp Workspace (Since version `0.1.4a0`)\n- [x] Panel. See [panel-graphic-walker](https://github.com/panel-extensions/panel-graphic-walker).\n- [x] marimo (Since version `0.4.9.11`)\n- [ ] Hex Projects \n- [ ] ...feel free to raise an issue for more environments.\n\n## Configuration And Privacy Policy(pygwalker \u003e= 0.3.10)\n\nYou can use `pygwalker config` to set your privacy configuration.\n\n```bash\n$ pygwalker config --help\n\nusage: pygwalker config [-h] [--set [key=value ...]] [--reset [key ...]] [--reset-all] [--list]\n\nModify configuration file. (default: ~/Library/Application Support/pygwalker/config.json) \nAvailable configurations:\n\n- privacy  ['offline', 'update-only', 'events'] (default: events).\n    \"offline\": fully offline, no data is send or api is requested\n    \"update-only\": only check whether this is a new version of pygwalker to update\n    \"events\": share which events about which feature is used in pygwalker, it only contains events data about which feature you arrive for product optimization. No DATA YOU ANALYSIS IS SEND. Events data will bind with a unique id, which is generated by pygwalker when it is installed based on timestamp. We will not collect any other information about you.\n    \n- kanaries_token  ['your kanaries token'] (default: empty string).\n    your kanaries token, you can get it from https://kanaries.net.\n    refer: https://space.kanaries.net/t/how-to-get-api-key-of-kanaries.\n    by kanaries token, you can use kanaries service in pygwalker, such as share chart, share config.\n    \n\noptions:\n  -h, --help            show this help message and exit\n  --set [key=value ...]\n                        Set configuration. e.g. \"pygwalker config --set privacy=update-only\"\n  --reset [key ...]     Reset user configuration and use default values instead. e.g. \"pygwalker config --reset privacy\"\n  --reset-all           Reset all user configuration and use default values instead. e.g. \"pygwalker config --reset-all\"\n  --list                List current used configuration.\n```\n\nMore details, refer it: [How to set your privacy configuration?](https://github.com/Kanaries/pygwalker/wiki/How-to-set-your-privacy-configuration%3F)\n\n# License\n\n[Apache License 2.0](https://github.com/Kanaries/pygwalker/blob/main/LICENSE)\n\n# Contribution Guideline\nYou are encouraged to contribute to PyGWalker in any way that suits your interests. This may include:\n- Answering questions and providing support\n- Sharing ideas for new features\n- Reporting bugs and glitches\n- Contributing code to the project\n- Offering suggestions for website improvements and better documentation\n\n# Resources\n\n\u003e PyGWalker Cloud is released! You can now save your charts to cloud, publish the interactive cell as a web app and use advanced GPT-powered features. Check out the [PyGWalker Cloud](https://kanaries.net/pygwalker?from=gh_md) for more details.\n\n+ Check out more resources about PyGWalker on [Kanaries PyGWalker](https://kanaries.net/pygwalker)\n+ PyGWalker Paper [PyGWalker: On-the-fly Assistant for Exploratory Visual Data Analysis\n](https://arxiv.org/abs/2406.11637)\n+ We are also working on [RATH](https://kanaries.net): an Open Source, Automate exploratory data analysis software that redefines the workflow of data wrangling, exploration and visualization with AI-powered automation. Check out the [Kanaries website](https://kanaries.net) and [RATH GitHub](https://github.com/Kanaries/Rath) for more!\n+ [Youtube: How to explore data with PyGWalker in Python\n](https://youtu.be/rprn79wfB9E?si=lAsJn1cAQnb-EklD)\n+ [Use pygwalker to build visual analysis app in streamlit](https://docs.kanaries.net/pygwalker/use-pygwalker-with-streamlit)\n+ Use [panel-graphic-walker](https://github.com/panel-extensions/panel-graphic-walker) to build data visualization apps with Panel.\n+ If you encounter any issues and need support, please join our [Discord](https://discord.gg/Z4ngFWXz2U) channel or raise an issue on github.\n+ Share pygwalker on these social media platforms if you like it!\n[![Reddit](https://img.shields.io/badge/share%20on-reddit-red?style=flat-square\u0026logo=reddit)](https://reddit.com/submit?url=https://github.com/Kanaries/pygwalker\u0026title=Say%20Hello%20to%20pygwalker%3A%20Combining%20Jupyter%20Notebook%20with%20a%20Tableau-like%20UI)\n[![HackerNews](https://img.shields.io/badge/share%20on-hacker%20news-orange?style=flat-square\u0026logo=ycombinator)](https://news.ycombinator.com/submitlink?u=https://github.com/Kanaries/pygwalker)\n[![Twitter](https://img.shields.io/badge/share%20on-twitter-03A9F4?style=flat-square\u0026logo=twitter)](https://twitter.com/share?url=https://github.com/Kanaries/pygwalker\u0026text=Say%20Hello%20to%20pygwalker%3A%20Combining%20Jupyter%20Notebook%20with%20a%20Tableau-alternative%20UI)\n[![Facebook](https://img.shields.io/badge/share%20on-facebook-1976D2?style=flat-square\u0026logo=facebook)](https://www.facebook.com/sharer/sharer.php?u=https://github.com/Kanaries/pygwalker)\n[![LinkedIn](https://img.shields.io/badge/share%20on-linkedin-3949AB?style=flat-square\u0026logo=linkedin)](https://www.linkedin.com/shareArticle?url=https://github.com/Kanaries/pygwalker\u0026\u0026title=Say%20Hello%20to%20pygwalker%3A%20Combining%20Jupyter%20Notebook%20with%20a%20Tableau-alternative%20UI)\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkanaries%2Fpygwalker","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkanaries%2Fpygwalker","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkanaries%2Fpygwalker/lists"}