-
-
Notifications
You must be signed in to change notification settings - Fork 74
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Extend DataFrame parameter support to other libraries #975
base: main
Are you sure you want to change the base?
Conversation
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #975 +/- ##
==========================================
- Coverage 86.70% 86.38% -0.32%
==========================================
Files 10 10
Lines 5151 5201 +50
==========================================
+ Hits 4466 4493 +27
- Misses 685 708 +23 ☔ View full report in Codecov by Sentry. |
@hoxbro @MarcSkovMadsen would love your thoughts. I'd like to think about Narwhals support but am wondering if that may be better implemented as a new parameter type. |
Co-authored-by: Simon Høxbro Hansen <[email protected]>
Co-authored-by: Simon Høxbro Hansen <[email protected]>
My POC for how this should be done from param over panel to bokeh is in https://github.com/panel-extensions/panel-graphic-walker/blob/89d6bac66d119d6ad1f75dfe27ec984d18d895ed/src/panel_gwalker/_tabular_data.py#L1 My broader vision for tabular support is in narwhals-dev/narwhals#1289 (comment). My recommendation would by to first implement this e2e in panel-graphic-walker. That is a place where its really easy to get this working and experimenting e2e. Its also a practical example that will help us have a specific discussion solving real problems. |
As we begin to broaden support for different DataFrame libraries in our ecosystem we need to start at the bottom and work our way up. This PR makes it possible for
param.DataFrame
to be extended with support for other DataFrame libraries and adds initial support for acceptingpolars
DataFrame
andLazyFrame
objects. For now we maintain backwards compatibility here and require the user to explicitly define which libraries they want to support by providing alibraries
argument.