为了账号安全,请及时绑定邮箱和手机立即绑定

没有值的 Pandas MultiIndex

没有值的 Pandas MultiIndex

慕桂英3389331 2023-04-11 15:49:15
我正在使用 MultiIndex,数据来自数据库。我想用作键的一些值是空的。我发现这会导致数据被省略。例如import numpy as npimport pandas as pdimport sysprint(sys.version)  # 3.7.3print(pd.__version__) # 1.0.3idx = pd.MultiIndex.from_tuples([('A', 'a'), ('A', 'b'), ('B', 'a'), ('B', ' '), ('C', 'a'), ('C', None), ('D', '')], names=['Level 1', 'Level 2'])print(idx)d = {'X':{('A','a'):1, ('A','b'):2, ('B','a'):3, ('B',' '):4, ('C','a'): 5, ('C',None): 6, ('D',''):7},'Y':{('A','a'):1, ('C',None): 6, ('D',''):7}}df = pd.DataFrame(data=d, index=idx)print(df)结果是:MultiIndex([('A', 'a'),            ('A', 'b'),            ('B', 'a'),            ('B', ' '),            ('C', 'a'),            ('C', nan),            ('D',  '')],           names=['Level 1', 'Level 2'])                   X    YLevel 1 Level 2A       a        1.0  1.0        b        2.0  NaNB       a        3.0  NaN                 4.0  NaNC       a        5.0  NaN        NaN      NaN  NaND                7.0  7.0我的问题是 C/None 行,它给了我NaN而不是 6。其他空白值(空字符串、空格)没有这种行为。这是可以预料的还是我需要以某种方式配置 MultiIndex?
查看完整描述

1 回答

?
胡子哥哥

TA贡献1825条经验 获得超6个赞

当索引中有 NaN 时,这是不安全的:github1 github2

对于简单的修复,您可以将数据加载到数据框,然后fillnaset_index返回



查看完整回答
反对 回复 2023-04-11
  • 1 回答
  • 0 关注
  • 91 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信