Plotly R:当每个 x 因子水平存在两个值时,无法绘制点因子、水平、存在、两个

2023-09-06 14:27:06 作者:被遺莣在街角de幸褔

I have a data frame like this:

dput(df)
structure(list(x = structure(c(1L, 2L, 3L, 4L, 5L, 1L, 2L, 3L, 
4L, 5L), .Label = c("41197708", "41223094", "41244000", "41244435", 
"41244936"), class = "factor"), y = c(1, 1, 1, 1, 1, 2, 2, 2, 
2, 2)), .Names = c("x", "y"), row.names = c(NA, -10L), class = "data.frame")

Trying to print a scatter plot with points as follows:

plot_ly(df, x = levels(x), y = y, mode = 'markers')
Learn R 交互可视化之Plotly包 一

I only see points corresponding to y = 1 and not y = 2. Any idea why?

The following works in plotly, but then it treats x axis values as numeric / continuous (not what I want):

plot_ly(df, x = x, y = y, mode = 'markers')

解决方案

Isn't this a duplicate of your previous question and related to this github issue ?

Currently you need to manually specify that you have a categorical axis.

plot_ly(df, x = x, y = y, mode = "markers") %>% layout(xaxis = list(type = "category"))

Right now we just sent the factor levels as a string to plotly.js

plotly_build(plot_ly(df, x = x, y = y, mode = "markers"))$data[[1]]$x

Based on those strings, plotly.js (correctly) thinks that you want a numeric axis. In the future, we should set smarter axis type defaults based on the variable mappings.

If you do:

plot_ly(df, x = x, y = y, mode = "markers") %>% 
      layout(xaxis = list(type = "category"))

You'll get: