我有几个要附加的数据框(形状相同),以创建一个更大的数据框。 Tee单个数据帧都具有以下类型:

C-Mastersheet.xlsx   <class 'pandas.core.frame.DataFrame'>
D-Mastersheet.xlsx   <class 'pandas.core.frame.DataFrame'>
L-Mastersheet.xlsx   <class 'pandas.core.frame.DataFrame'>

看起来像:

C-Mastersheet.xlsx
   First Name  Last name        Dept  Location  Status      Concat
0          Jo      Jones    Accounts   Bristol Current     JonesJo
1         Sid      Smith       Sales      Hull     New    SmithSid

D-Mastersheet.xlsx
       First Name  Last name        Dept  Location  Status      Concat
0            Phil      Evans  Production      Hull Current   EvansPhil
1           Sarah      Heath   Marketing   Bristol Current  HeathSarah
2            Jane       Hill    Accounts   Bristol Current    HillJane
3             Amy     Cooper       Sales      Hull Current   CooperAmy

L-Mastersheet.xlsx
   First Name  Last name        Dept  Location  Status      Concat
0      Marcus      Price  Operations      Hull Current PriceMarcus
1      Andrew       King      Design   Bristol Current  KingAndrew
2        Emma       Lane   Marketing   Bristol Current    LaneEmma
3       Brian       Deen    Accounts   Bristol Current   DeenBrian
4       Steve      Jacks      Design   Bristol Current  JacksSteve

我试图返回输出:
  First Name  Last name        Dept  Location   Status      Concat
 0         Jo      Jones    Accounts   Bristol Current     JonesJo
 1        Sid      Smith       Sales      Hull New        SmithSid
 2       Phil      Evans  Production      Hull Current   EvansPhil
 3      Sarah      Heath   Marketing   Bristol Current  HeathSarah
 4       Jane       Hill    Accounts   Bristol Current    HillJane
 5        Amy     Cooper       Sales      Hull Current   CooperAmy
 6     Marcus      Price  Operations      Hull Current PriceMarcus
 7     Andrew       King      Design   Bristol Current  KingAndrew
 8       Emma       Lane   Marketing   Bristol Current    LaneEmma
 9      Brian       Deen    Accounts   Bristol Current   DeenBrian
10      Steve      Jacks      Design   Bristol Current  JacksSteve

我正在尝试使用以下目录中的以下代码循环来做到这一点:
ConsolidatedData = pd.DataFrame

for i in os.listdir(os.chdir(returnsfolder)):
    if i.endswith(".xlsx"):
        )
        rawFilePath = returnsfolder +'\\'+ i

        DeptReturn = openRawDeptReturn(rawFilePath)

        ConsolidatedData = ConsolidatedData.append(DeptReturn,ignore_index=True)

但是,我收到以下类型错误:
TypeError: append() missing 1 required positional argument: 'other'

我以前没有遇到过。

最佳答案

这就是问题:

df = pd.DataFrame           # returns class
df = df.append(DeptReturn)  # TypeError: append() missing 1 required positional argument: 'other'

错误背后的原因是方法的第一个参数是类实例。在这种情况下,类实例被推断为DeptReturn,并且不提供'other'参数。

您需要的是:
df = pd.DataFrame()         # returns class instance
df = df.append(DeptReturn)  # returns instance with method applied

对于第一个参数,我们使用类实例df,因为该方法将应用于该实例。第二个参数是DeptReturn

另请参阅:What is the purpose of self?

09-26 12:20