【问题标题】:Can't Add Columns After Transposing Pandas DataFrame转置 Pandas DataFrame 后无法添加列
【发布时间】:2014-07-01 00:27:29
【问题描述】:

所以我有一个看起来像这样的 DataFrame:

a = pd.DataFrame({'A':[1,2,3],'B':[4,5,6]})

我可以转置它,并轻松添加一个带有值的新列:

aT = a.T
aT['C']=1

但是,如果我将日期索引添加到原始数据框,然后转置它,我无法将任何新列添加到转置中。

a.index = pd.date_range('20130101',periods=3)
aT = a.T
aT['C']=1

抛出错误:

ValueError                                Traceback (most recent call last)
<ipython-input-11-703e95b478c3> in <module>()
----> 1 aT['C']=1

/Users/maxsong/anaconda/lib/python2.7/site-packages/pandas/core/frame.pyc in __setitem__(self, key, value)
   2117         else:
   2118             # set column
-> 2119             self._set_item(key, value)
   2120 
   2121     def _setitem_slice(self, key, value):

/Users/maxsong/anaconda/lib/python2.7/site-packages/pandas/core/frame.pyc in _set_item(self, key, value)
   2164         """
   2165         value = self._sanitize_column(key, value)
-> 2166         NDFrame._set_item(self, key, value)
   2167 
   2168     def insert(self, loc, column, value, allow_duplicates=False):

/Users/maxsong/anaconda/lib/python2.7/site-packages/pandas/core/generic.pyc in _set_item(self, key, value)
    677 
    678     def _set_item(self, key, value):
--> 679         self._data.set(key, value)
    680         self._clear_item_cache()
    681 

/Users/maxsong/anaconda/lib/python2.7/site-packages/pandas/core/internals.pyc in set(self, item, value)
   1779         except KeyError:
   1780             # insert at end
-> 1781             self.insert(len(self.items), item, value)
   1782 
   1783         self._known_consolidated = False

/Users/maxsong/anaconda/lib/python2.7/site-packages/pandas/core/internals.pyc in insert(self, loc, item, value, allow_duplicates)
   1799             # so our insertion operation failed, so back out of the new items
   1800             # GH 3010
-> 1801             new_items = self.items.delete(loc)
   1802             self.set_items_norename(new_items)
   1803 

/Users/maxsong/anaconda/lib/python2.7/site-packages/pandas/tseries/index.pyc in delete(self, loc)
   1478         new_index : DatetimeIndex
   1479         """
-> 1480         arr = np.delete(self.values, loc)
   1481         return DatetimeIndex(arr, tz=self.tz)
   1482 

/Users/maxsong/anaconda/lib/python2.7/site-packages/numpy/lib/function_base.pyc in delete(arr, obj, axis)
   3454         if (obj < 0 or obj >=N):
   3455             raise ValueError(
-> 3456                     "invalid entry")
   3457         newshape[axis]-=1;
   3458         new = empty(newshape, arr.dtype, arr.flags.fnc)

ValueError: invalid entry 

【问题讨论】:

  • 这对我来说很好用...使用 pandas 0.13.1。在尝试添加列之前,您的第二个 aT 变量是否看起来像您认为的那样?
  • 我使用的是 0.12.0 - 在使用 pip install --upgrade pandas 升级 pandas 0.14.0 后工作

标签: python pandas transpose


【解决方案1】:

这适用于我的 pandas 0.14.0,你应该至少升级到 0.13

【讨论】:

    猜你喜欢
    • 2020-12-28
    • 1970-01-01
    • 1970-01-01
    • 2020-12-31
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多