您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

python – Pandas – 类别变量和分组 – 这是一个错误吗?

5b51 2022/1/14 8:21:56 python 字数 2503 阅读 510 来源 www.jb51.cc/python

我在玩熊猫时遇到了一个奇怪的结果,我不知道为什么会这样.想知道它是不是一个bug.cf = pd.DataFrame({'sc': ['b' , 'b', 'c' , 'd'], 'nn': [1, 2, 3, 4], 'mvl':[10, 20, 30, 40]}) df = cf.groupby('sc').mean() df.loc['b', 'mvl

概述

我在玩熊猫时遇到了一个奇怪的结果,我不知道为什么会这样.想知道它是不是一个bug.

cf = pd.DataFrame({'sc': ['b','b','c','d'],'nn': [1,2,3,4],'mvl':[10,20,30,40]})
df = cf.groupby('sc').mean()
df.loc['b','mvl']

结果给出“15.0”.

cf1 = cf
cf1['sc'] = cf1['sc'].astype('category',categories=['b',ordered = True)
df1 = cf1.groupby('sc').mean()
df1.loc['b','mvl']

这给出了一个系列:

sc

b    15.0
Name: mvl,dtype: float64

type(df1.loc [‘b’,’mvl’]) – > pandas.core.series.Series

type(df.loc [‘b’,’mvl’]) – > numpy.float64

为什么将变量声明为分类会将loc的输出从标量更改为系列?

我希望这不是一个愚蠢的问题.谢谢!

nocat = pandas.Series(['a','c'])
cat = nocat.astype('category',categories=['a','c'],ordered=True)
xno = pandas.Series([8,88,888],index=nocat)
xcat = pandas.Series([8,index=cat)

>>> xno.loc['a']
8
>>> xcat.loc['a']
a    8
dtype: int64

docs注意到CategoricalIndex上的索引操作保留了分类索引.看起来他们甚至会这样做,如果你只得到一个结果,这并不完全与文档相矛盾,但似乎是不良行为.

一个a related pull request似乎解决了这种行为,但它最近才合并.看起来修复应该在pandas 0.18.1中.

总结

以上是编程之家为你收集整理的python – Pandas – 类别变量和分组 – 这是一个错误吗?全部内容,希望文章能够帮你解决python – Pandas – 类别变量和分组 – 这是一个错误吗?所遇到的程序开发问题。


如果您也喜欢它,动动您的小指点个赞吧

除非注明,文章均由 laddyq.com 整理发布,欢迎转载。

转载请注明:
链接:http://laddyq.com
来源:laddyq.com
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


联系我
置顶