微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python – ValueError:值的长度与索引的长度不匹配Pandas DataFrame.unique()

我正在尝试获取新数据集,或将当前数据集列的值更改为其唯一值.
这是我想要得到的一个例子:

   A B
 -----
0| 1 1
1| 2 5
2| 1 5
3| 7 9
4| 7 9
5| 8 9

Wanted Result    Not Wanted Result
       A B            A B
     -----          -----
    0| 1 1         0| 1 1
    1| 2 5         1| 2 5
    2| 7 9         2| 
    3| 8           3| 7 9
                   4|
                   5| 8

我真的不关心索引,但似乎是问题所在.
到目前为止,我的代码非常简单,我尝试了两种方法,一种是使用新的dataFrame而另一种是没有.

#With New DataFrame
 def UniqueResults(dataframe):
    df = pd.DataFrame()
    for col in dataframe:
        S=pd.Series(dataframe[col].unique())
        df[col]=S.values
    return df

#Without new DataFrame
def UniqueResults(dataframe):
    for col in dataframe:
        dataframe[col]=dataframe[col].unique()
    return dataframe

我有两次错误“值的长度与索引的长度不匹配”.

解决方法:

当您尝试将不同长度的numpy数组列表分配给数据帧时,会出现错误,并且可以按如下方式重现:

四行数据框:

df = pd.DataFrame({'A': [1,2,3,4]})

现在尝试为其分配两个元素的列表/数组:

df['B'] = [3,4]   # or df['B'] = np.array([3,4])

两个错误

ValueError: Length of values does not match length of index

因为数据框有四行,但列表和数组只有两个元素.

解决方案(谨慎使用):将列表/数组转换为pandas系列,然后在执行赋值时,系列中缺少的索引将填充NaN:

df['B'] = pd.Series([3,4])

df
#   A     B
#0  1   3.0
#1  2   4.0
#2  3   NaN          # NaN because the value at index 2 and 3 doesn't exist in the Series
#3  4   NaN

对于您的特定问题,如果您不关心索引或列之间的值的对应关系,则可以在删除重复项后重置每列的索引:

df.apply(lambda col: col.drop_duplicates().reset_index(drop=True))

#   A     B
#0  1   1.0
#1  2   5.0
#2  7   9.0
#3  8   NaN

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐