Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >堆叠条形图返回意外输出(Python,绘图)

堆叠条形图返回意外输出(Python,绘图)
EN

Stack Overflow用户
提问于 2021-02-10 09:09:24
回答 1查看 74关注 0票数 2

我有一个包含三列(Day-ShiftStateseconds)的df

代码语言:javascript
运行
AI代码解释
复制
Day-Shift   State          seconds
Day 01-05   A              7439
Day 01-05   STOPPED        0
Day 01-05   B              10
Day 01-05   C              35751
Night 01-05 C              43200
Day 01-06   STOPPED        7198
Day 01-06   F              18
Day 01-06   A              14
Day 01-06   A              29301
Day 01-06   STOPPED        6
Day 01-06   A              6663
Night 01-06 A              43200

我构建堆叠条形图的代码是:

代码语言:javascript
运行
AI代码解释
复制
import plotly.express as px
fig = px.bar(df, x="Day-Shift", y="seconds", color="State")
fig.show()

但它会返回这个堆叠的条形图。

这里的错误是更改了Day-Shift顺序,并且相应的秒数不在此图表中。我找不到错误。非常感谢您的支持!

DF:

代码语言:javascript
运行
AI代码解释
复制
{'Day-Shift': {0: 'Day 01-05',
  1: 'Day 01-05',
  2: 'Day 01-05',
  3: 'Day 01-05',
  4: 'Night 01-05',
  5: 'Day 01-06',
  6: 'Day 01-06',
  7: 'Day 01-06',
  8: 'Day 01-06',
  9: 'Day 01-06',
  10: 'Day 01-06',
  11: 'Night 01-06',
  12: 'Day 01-07',
  13: 'Night 01-07',
  14: 'Night 01-07',
  15: 'Night 01-07',
  16: 'Night 01-07',
  17: 'Night 01-07',
  18: 'Night 01-08',
  19: 'Night 01-08',
  20: 'Night 01-08',
  21: 'Night 01-08',
  22: 'Day 01-08',
  23: 'Day 01-08',
  24: 'Day 01-08',
  25: 'Night 01-09',
  26: 'Night 01-09',
  27: 'Night 01-09',
  28: 'Day 01-09',
  29: 'Day 01-09',
  30: 'Day 01-09',
  31: 'Day 01-09',
  32: 'Day 01-10',
  33: 'Night 01-10',
  34: 'Day 01-11',
  35: 'Day 01-11',
  36: 'Day 01-11',
  37: 'Day 01-11',
  38: 'Day 01-11',
  39: 'Night 01-11',
  40: 'Day 01-12',
  41: 'Night 01-12',
  42: 'Day 01-13',
  43: 'Day 01-13',
  44: 'Day 01-13',
  45: 'Day 01-13',
  46: 'Day 01-13',
  47: 'Day 01-13',
  48: 'Day 01-13',
  49: 'Night 01-13',
  50: 'Day 01-14',
  51: 'Day 01-14',
  52: 'Day 01-14',
  53: 'Day 01-14',
  54: 'Day 01-14',
  55: 'Day 01-14',
  56: 'Day 01-14',
  57: 'Day 01-14',
  58: 'Day 01-14',
  59: 'Night 01-14'},
 'State': {0: 'D',
  1: 'STOPPED',
  2: 'B',
  3: 'A',
  4: 'A',
  5: 'A',
  6: 'A1',
  7: 'A2',
  8: 'A3',
  9: 'A4',
  10: 'B1',
  11: 'B1',
  12: 'B1',
  13: 'B1',
  14: 'B2',
  15: 'STOPPED',
  16: 'RUNNING',
  17: 'B',
  18: 'STOPPED',
  19: 'B',
  20: 'RUNNING',
  21: 'D',
  22: 'STOPPED',
  23: 'B',
  24: 'RUNNING',
  25: 'STOPPED',
  26: 'RUNNING',
  27: 'B',
  28: 'RUNNING',
  29: 'STOPPED',
  30: 'B',
  31: 'D',
  32: 'B',
  33: 'B',
  34: 'B',
  35: 'RUNNING',
  36: 'STOPPED',
  37: 'D',
  38: 'A',
  39: 'A',
  40: 'A',
  41: 'A',
  42: 'A',
  43: 'A1',
  44: 'A2',
  45: 'A3',
  46: 'A4',
  47: 'B1',
  48: 'B2',
  49: 'B2',
  50: 'B2',
  51: 'B',
  52: 'STOPPED',
  53: 'A',
  54: 'A1',
  55: 'A2',
  56: 'A3',
  57: 'A4',
  58: 'B1',
  59: 'B1'},
 'seconds': {0: 7439,
  1: 0,
  2: 10,
  3: 35751,
  4: 43200,
  5: 7198,
  6: 18,
  7: 14,
  8: 29301,
  9: 6,
  10: 6663,
  11: 43200,
  12: 43200,
  13: 5339,
  14: 8217,
  15: 0,
  16: 4147,
  17: 1040,
  18: 24787,
  19: 1500,
  20: 14966,
  21: 1410,
  22: 2499,
  23: 1310,
  24: 39391,
  25: 3570,
  26: 17234,
  27: 47390,
  28: 36068,
  29: 270,
  30: 6842,
  31: 20,
  32: 43200,
  33: 43200,
  34: 2486,
  35: 8420,
  36: 870,
  37: 30,
  38: 31394,
  39: 43200,
  40: 43200,
  41: 43200,
  42: 36733,
  43: 23,
  44: 6,
  45: 4,
  46: 4,
  47: 3,
  48: 6427,
  49: 43200,
  50: 620,
  51: 0,
  52: 4,
  53: 41336,
  54: 4,
  55: 4,
  56: 4,
  57: 23,
  58: 1205,
  59: 43200}}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-10 09:59:48

您的代码片段似乎在我这一端运行得很好:

代码语言:javascript
运行
AI代码解释
复制
import plotly.express as px
fig = px.bar(df, x="Day-Shift", y="seconds", color="State")
fig.show()

并生成这个图:

所以要么是你的版本有问题,要么更有可能是你的数据有问题。您应该做的第一件事是确保您的任何数据都没有被转换为索引。您可以使用df = df.reset_index()轻松地重置索引。在下面的代码片段中,您将看到我将您的相同数据集用作没有索引的字典。

编辑:轴格式

在上图中,以绘图方式将X轴解释为时间值。如果你想防止这种情况,只需包含fig.update_xaxes(type='category')即可获得以下内容:

完整代码:

代码语言:javascript
运行
AI代码解释
复制
import pandas as pd
import plotly.express as px

# df = pd.read_clipboard(sep='\\s+').reset_index()
# df.to_dict()
df = pd.DataFrame({'index': {0: 'Day',
                              1: 'Day',
                              2: 'Day',
                              3: 'Day',
                              4: 'Night',
                              5: 'Day',
                              6: 'Day',
                              7: 'Day',
                              8: 'Day',
                              9: 'Day',
                              10: 'Day',
                              11: 'Night'},
                             'Day-Shift': {0: '01-05',
                              1: '01-05',
                              2: '01-05',
                              3: '01-05',
                              4: '01-05',
                              5: '01-06',
                              6: '01-06',
                              7: '01-06',
                              8: '01-06',
                              9: '01-06',
                              10: '01-06',
                              11: '01-06'},
                             'State': {0: 'A',
                              1: 'STOPPED',
                              2: 'B',
                              3: 'C',
                              4: 'C',
                              5: 'STOPPED',
                              6: 'F',
                              7: 'A',
                              8: 'A',
                              9: 'STOPPED',
                              10: 'A',
                              11: 'A'},
                             'seconds': {0: 7439,
                              1: 0,
                              2: 10,
                              3: 35751,
                              4: 43200,
                              5: 7198,
                              6: 18,
                              7: 14,
                              8: 29301,
                              9: 6,
                              10: 6663,
                              11: 43200}})

import plotly.express as px
fig = px.bar(df, x="Day-Shift", y="seconds", color="State")
fig.show()
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66133861

复制
相关文章
【技巧】GraphPad Prism柱状图Y轴截断
从上表可以看出,A组、B组的数据明显比C组、D组、E组要大,这种差异较大的数据做出的柱状图效果如下:
Mark Chen
2020/07/20
37.6K0
Serverless冷扩机器在压测中被击穿问题
Tech 导读 机器扩容后瞬间被高流量击穿,背后发生了什么?本文从实际案例入手,探讨在冷启动的场景下如何保护系统不被瞬间流量压垮。
京东技术
2023/08/22
1550
Serverless冷扩机器在压测中被击穿问题
让WordPress 在RSS 中Feed 截断文字输出
本文是《让WordPress 在RSS 中Feed 输出支持“More”标签》的姊妹篇,相信你也知道,WordPress摘要输出文章是惨不忍睹的,但是全文输出又不和博主的意愿。我们可以截断部分文字输出,配合加上版权信息,完美解决! 要截断文字输出的话,相信你也知道了,是用 mb_strimwidth 函数,下面直接献上Jeff的代码吧——Jeff的阳台 就是用这段代码的: //在RSS 中Feed 截断文字输出 devework.com function dw_readmore_rss( $content
Jeff
2018/01/19
2.1K0
让WordPress 在RSS 中Feed 截断文字输出
截断梯度
强非线性函数往往倾向于非常大或非常小幅度的梯度。这导致的困难是,当参数梯度非常大时,梯度下降的参数更新可以将参数抛出很远,进入目标函数较大的区域,到达当前解所做的努力变成了无用功。梯度告诉我们,围绕当前参数的无穷小区域内最速下降的方向,这个无穷小区域之外,代价函数可能开始沿曲线背面而上。更新必须被选择为足够小,以避免过分穿越向上的曲面。我们通常使用衰减足够慢的学习率,使连续的步骤具有大致相同的学习率。适合于一个相对线性的地形部分的步长经常在下一步进入地形中更加弯曲的部分时变得不适合,会导致上坡运动。
狼啸风云
2020/01/13
2.1K0
截断梯度
截断数组
数据范围 前六个测试点满足 1≤n≤10 。 所有测试点满足 1≤n≤105 ,−10000≤ai≤10000 。
凡尘扰凡心
2023/02/13
7350
MatLab函数ylabel、ylim、yticks、yticklabels、ytickformat
【注】x、z 轴对应函数同理;具体函数详解在 MatLab 中使用命令 help func 查阅。
hotarugali
2022/02/28
3.2K0
MatLab函数ylabel、ylim、yticks、yticklabels、ytickformat
截断数组
Original Link 思想: 前缀和。 特殊情况: 当数组元素小于三个时,无解。 当该数组所有数之和不为 3 的整数倍时,无解。 设数组均分的值为 res,循环遍历前缀和数组 a。 设 i 为分割点,若 a[i] == res,说明将 i 作为分割点有可能成立,记录分割点数量为 cnt ++。 设 n - i + 1 为第二个分割点,若 a[n] - a[n - i + 1] == res,则说明该分割点可以与 i 之前的所有分割点进行分割数组,记录分割方案为 ans += cnt。 代码: #
浪漫主义狗
2023/02/21
2.2K0
截断数组
数据范围 前六个测试点满足 1≤n≤10 。 所有测试点满足 1≤n≤105 ,−10000≤ai≤10000 。
凡尘扰凡心
2023/02/27
7580
截断数组
MATLAB截断数组
s1 = randi([400, 3000],189,1);s1 = sort(s1);s1(1,1) = 400;s1(189,1) = 3000;s1 = s1/1000;lambda = s1;%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到100的元素%取1到10
狼啸风云
2019/04/09
1.6K0
【R语言】如何绘制截断Y轴的柱形图
在绘制柱形图的时候, 我们经常会遇到Y轴部分数据范围很广的情况。有些数值很大,但是有些有非常小,不在一个尺度范围内。如果直接使用最大值作为y轴的范围,那么那些数值很小的柱子就会显得很矮,画出来的图会很难看。遇到这种情况我们该如何处理呢?今天就给大家分享一下截断Y轴的柱形图。
生信交流平台
2022/09/21
2.3K0
【R语言】如何绘制截断Y轴的柱形图
面试中被问到SQL优化
数据库通过锁机制来解决并发场景-共享锁(读锁)和排他锁(写锁)。读锁是不阻塞的,多个客户端可以在同一时刻读取同一个资源。写锁是排他的,并且会阻塞其他的读锁和写锁。简单提下乐观锁和悲观锁。
用户4283147
2022/10/27
5370
面试中被问到SQL优化
Pandas基础:在Pandas数据框架中移动列
有时候,我们需要在pandas数据框架内移动一列,shift()方法提供了一种方便的方法来实现。
fanjy
2022/06/04
3.3K0
Pandas基础:在Pandas数据框架中移动列
在R语言和Stan中估计截断泊松分布
这是一个非常简化的例子。我模拟了1,000个计数观察值,平均值为1.3。然后,如果只观察到两个或更高的观察,我将原始分布与我得到的分布进行比较。
拓端
2020/12/30
1.1K0
在R语言和Stan中估计截断泊松分布
用pandas绘制箱体图(boxplot)
箱体图是一种用于表示分布的图像,由五个分位数组成。很好用的图,但是excel要生成这个可就得曲线救国了,然而如果用python加上pandas的话就很easy啦。
钱塘小甲子
2019/01/28
1.5K0
Python中被忽略的else
else, 我们再熟悉不过了。对于一个python程序员来说,else往往都是配合if来使用的,像这样:
Python中文社区
2018/07/26
7180
Python 中被忽略的 else
来源:Python中文社区 ID:python-china else, 我们再熟悉不过了。对于一个python程序员来说,else往往都是配合if来使用的,像这样: a = '12'if a == '123': print(a)else: print('出错了!') 但是,python中的else并不只能用在if之后,so,这次我们讨论一下Python流程控制中的else。 else子句不仅能在if 语句中使用,还能在 for、while 和 try 语句中使用,这个语言特性不是什么秘密,但却
小小科
2018/06/20
6420
文本溢出截断省略
文本溢出截断省略是比较常见的业务场景,主要分为单行文本溢出截断省略与多行文本溢出截断省略,单行的截断方案比较简单,多行截断相对比较复杂。
WindRunnerMax
2020/08/27
1.7K0
Python数据分析之Seaborn(热图绘制)
[Style functions]http://seaborn.pydata.org/tutorial/aesthetics.html#aesthetics-tutorial
AI异构
2020/07/29
4.6K0
Python数据分析之Seaborn(热图绘制)
Python数据处理从零开始----第四章(可视化)①③多变量绘图目录
科研工作中我们经常需要把每两个变量之间的关系计算, 然后可以得到一个相关矩阵。 如果两个变量的变化趋势一样, 那么这个值就会大于零, 表明连个变量正相关,值越大代表相关性越强。 相反的话,如果两个变量的变化趋势相反, 这个值就会小于零。我们经常需要关注这个值,是因为在许多机器学习算法中,强相关的变量会导致算法能力下降。
用户1359560
2018/12/21
5140
点击加载更多

相似问题

使用SQLAlchemy继承选择特定列

10

SQLAlchemy选择多个列,如内连接

15

如何在sqlalchemy中选择多列连接的特定列?

11

使用SQLAlchemy选择具有强制转换的特定列

122

sqlalchemy:使用别名从多个联接中选择特定列

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档