KeyError:“轴中不包含标签[data]”

时间:2018-06-27 14:37:29

标签: python pandas append typeerror delete-row

我尝试了几种不同的方法将行添加到现有的Pandas Dataframe中。例如,我尝试了解决方法here。但是,我无法纠正此问题。我已恢复为原始代码,希望有人能在这里为我提供帮助。

这是我的代码:

print('XDF Created, Starting Bucket Separation...')
XDFDFdrop = pd.DataFrame.duplicated(XDFDF,subset='LastSurveyMachineID')
index_of_unique = XDFDF.drop_duplicates(subset='LastSurveyMachineID')
for index,row in zip(XDFDFdrop,XDFDF.itertuples()):
    if index:
        goodBucket.append(row)
    else:
        badBucket.append(row)
goodBucketDF = pd.DataFrame(goodBucket)
badBucketDF = pd.DataFrame(badBucket)

print('Bucket Separation Complete, EmailPrefix to F+L Test Starting...')
for emp , fname , lname , row1 in zip(goodBucketDF['EmailPrefix'] , goodBucketDF['Fname'] , goodBucketDF['Lname'] , goodBucketDF.itertuples()):
    for emp2 , row2 in zip(goodBucketDF['EmailPrefix'] , goodBucketDF.itertuples()):
        if columns != rows:
            temp = fuzz.token_sort_ratio((fname+lname),emp)
            temp2 = fuzz.token_sort_ratio((fname+lname),emp2)
            if abs(temp - temp2) < 10:
                badBucketDF.append(list(row2))
                goodBucketDF = goodBucketDF.drop(row2)
                removed = True
        rows += 1
    if removed:
        badBucketDF.append(list(row2))
        goodBucketDF = goodBucketDF.drop(row2)
        removed = False
    columns += 1

请注意:XDFDF是一个使用熊猫构建的相对较大的数据集,并且是从数据库中提取的(它不会影响您看到的代码,因为我认为我会公开该信息)。

这是我的错误:

Traceback (most recent call last):
  File "/Users/john/PycharmProjects/Greatness/venv/Recipes.py", line 122, in <module>
    goodBucketDF = goodBucketDF.drop([rows])
  File "/Users/john/PycharmProjects/Greatness/venv/lib/python3.6/site-packages/pandas/core/frame.py", line 3694, in drop
    errors=errors)
  File "/Users/john/PycharmProjects/Greatness/venv/lib/python3.6/site-packages/pandas/core/generic.py", line 3108, in drop
    obj = obj._drop_axis(labels, axis, level=level, errors=errors)
  File "/Users/john/PycharmProjects/Greatness/venv/lib/python3.6/site-packages/pandas/core/generic.py", line 3140, in _drop_axis
    new_axis = axis.drop(labels, errors=errors)
  File "/Users/john/PycharmProjects/Greatness/venv/lib/python3.6/site-packages/pandas/core/indexes/base.py", line 4387, in drop
    'labels %s not contained in axis' % labels[mask])
KeyError: 'labels [(15, '1397659289', 'joshi.penguin@gmail.com', 'jim', 'smith', '1994-05-04', 'joshi.penguin', 'CF032611-8A86-4688-9715-E1278E75D046')] not contained in axis'

以退出代码1完成的过程

我想知道是否有人对此错误有解决方案,以便:我可以从一个数据框添加一行,然后将其放入另一个数据框(不需要按顺序排列,而我不需要不必担心索引是否重复)。一旦将其放入新的Dataframe中,我想将其从旧的Dataframe中删除。

我当前的问题是从旧的Dataframe中删除该行。任何帮助,将不胜感激。

如果您对代码有任何疑问,请告诉我,我会尽快答复。谢谢您的帮助。

编辑1

下面,我包括了第1行的打印输出。希望这也会有所帮助。

Pandas(Index=1, _1=2, entity_id='1180722688', email='assassin_penguin@live.com', Fname='jim', Lname='smith', Birthdate='1990-09-14', EmailPrefix='assassin_penguin', LastSurveyMachineID=None)

1 个答案:

答案 0 :(得分:1)

鉴于XDFDF是pandas.DataFrame,以下工作不应该吗?

XDFDFdrop = pd.DataFrame.duplicated(XDFDF,subset='LastSurveyMachineID')
goodBucket = XDFDF.loc[~XDFDFdrop] #the ~ negates a boolean array
badBucket = XDFDF.loc[XDFDFdrop]

编辑:

更新的错误来自于您向函数pandas.DataFrame.drop传递了整行而不是索引。