-
Notifications
You must be signed in to change notification settings - Fork 21
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Release the spec as PyPI package #73
Comments
Thanks @vnlitvinov
I think the main thing is that a runtime dependency is expensive, and I would not imagine Pandas or others would want a new dependency just for some improved type hinting. Nor would I recommend anyone doing that - vendoring seems preferable here. In which case, does it make sense to release a PyPI package - just tagging versions may be better? |
That's a good point, though I personally don't think it is so expensive, given how many packages usually a library already depends on, and taking into account that this particular package would be updated very rarely. But anyway... I think I will make a PR preparing for the package (probably without |
We've also started working on a simple, "smoke"-like test suite which should be pluggable anywhere (@Rubtsowa is working on that now). |
Related, the |
@vnlitvinov given that all that is left in this repo is a single file, |
Maybe implementors (like pandas) don't need such an additional dependency, but downstream users would benefit from it I think. Both Altair (vega/altair#2888) and Plotly Express (plotly/plotly.py#3387) seem to make use of
which would definitely help during development. |
Big +1 to publishing My experience using both the interchange protocol and the dataframe API is that it's not a great user experience to type such unergonomic and unusual names (e.g. Being able to tab-complete would be a big plus Regarding dependencies - this definitely wouldn't be a runtime dependency of pandas', but consumers of the api / interchange protocol could use it as a dev dependency |
xref #278 |
Hello everyone!
I've been mulling over introducing the Dataframe Exchange protocol in Pandas and Modin, and I think it would be beneficial for every end library implementing the protocol to have the exact same base.
Right now the protocol interface is defined by code, but said code is not "published" as a ready to use Python source.
I would like to make it a real PyPI package to use it in type hinting and (ideally)
mypy
type checking and to enable other libraries to do the same.I propose to publish the package as
dataframe-protocol
ordf-protocol
and renameprotocol/
directory todf_protocol
turning it in a real Python package.That way any library which would be implementing the protocol would just
from df_protocol import exchange
and use it for type hints (and for enum values - as now they're embedded in docstrings which just look really weird to me).Am I missing something here? Are there any objections?
I can make the PR with necessary changes if there is the agreement, and can keep it published both in PyPI and conda-forge (or can turn the publishing to someone else in the consortium).
P.S. Keeping the top-level
df_protocol
would allow us to add another subpackage for cross-operation API if/when we feel ready for that (so keeping this future-proof).The text was updated successfully, but these errors were encountered: