首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Dash中的RangeSlider问题

Dash中的RangeSlider问题
EN

Stack Overflow用户
提问于 2022-03-05 18:23:46
回答 1查看 246关注 0票数 0

我正在开发一个Dash,并且有一个允许选择日期范围的RangeSlider元素。以下是代码:

代码语言:javascript
复制
dcc.RangeSlider(
                    id='my-range-slider',
                    marks={timegm(datetime.strptime(years_list[i], '%Y-%m').utctimetuple()): {"label": years_list[i], "style": {"transform": "rotate(45deg)"}}
                           for i in range(len(years_list))},
                    min=min_value,
                    max=max_value,
                    value=[min_value,max_value],
                    step=1,
                )

其中"years_list“是日期字符串的列表。RangeSlider连接到一个图形,但问题是years_list太长,标记看起来像下面的图像,而如果列表不是太长,则值是好的。

有办法限制RangeSlider中可见标记的数量吗?或者解决这个图形问题的方法?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-05 18:59:45

您可以使用range()函数的“步骤”参数来调整范围滑块上的标记数。您可以选择最大数量的标记来保持用户界面的整洁。

代码语言:javascript
复制
import math
qty_of_years = len(years_list)
maximum_number_of_slider_marks = 20  # You pick max qty for good visuals in user interface
step_required_for_range = math.ceil(qty_of_years/maximum_number_of_slider_marks)

marks={timegm(datetime.strptime(years_list[i], '%Y-%m').utctimetuple()): {"label": years_list[i], "style": {"transform": "rotate(45deg)"}}
                           for i in range(0, qty_of_years, step_required_for_range)},
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71364828

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档