-
Notifications
You must be signed in to change notification settings - Fork 796
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
Support Vega-Lite's optional encoding types #2584
Comments
Thanks for raising this! That would be great. One choice we have to make is whether to continue inferring the dtype from pandas dataframes, or just leave all type inference to Vega-Lite. I lean toward the latter, so that the behavior will be the same regardless of how the data is specified. What do you think? |
I can see benefits of both approaches, but overall I am leaning towards keeping (and extending) the support for pandas data types. If Vega-Lite would be able to infer quantitative and temporal data, then I would be more in favor of relying on its type inference (vega/vega-lite#8081). Here are my thoughts in more detail:
|
To be clear, I still think it would be a big benefit to support the default Vega-Lite typing inference outside of pandas and I think it would enable us to have a clearer error message for typos in column names when using Altair. |
That's a good point, in your example it would be difficult to tell what went wrong in the first chart and it would not be intuitive that a change of the type is needed when using the URL since it is not when using the dataframe. If we go ahead with making a change here, we might need to handle URLs and dataframes differently and always require types for URLs still. That could still be worthwhile if it would clear up the error messages. |
I just want to make note of two comments by @mattijn that are possibly relevant to this discussion: |
@joelostblom @ChristopherDavisUCI Looking at this issue retrospectively, it seems you explored the topic and the outcome was a worse UX. |
I think with the example @ChristopherDavisUCI showed, it seems that supporting the default types might be more confusing than keeping the error message the way it is, so let's close for now. |
Since 4.14, the encoding
type
is optional in Vega-Lite and inferred according to some simple heuristics if not given explicitly. Altair raises an error if there is no type provided, but maybe we can remove this check now and just let Vega-Lite handle missing types? This could also make error such as misspelling a data frame column name more clear in Altair (which now raises the "field specified without type" error).Example:
Although the VegaLite spec is valid and produces a sensible figure in this case:
Open the Chart in the Vega Editor
The text was updated successfully, but these errors were encountered: