Ich habe einen Datenrahmen (df), der so aussieht:

a                      b
loc.1  [1, 2, 3, 4, 7, 5, 6]
loc.2  [3, 4, 3, 7, 7, 8, 6]
loc.3  [1, 4, 3, 1, 7, 8, 6]
...

Ich möchte das Maximum des Arrays in Spalte b finden und dieses an den ursprünglichen Datenrahmen anhängen. Mein Gedanke war ungefähr so:

for line in df: 
    split = map(float,b.split(','))
    count_max = max(split)
print count

Ideale Ausgabe sollte sein:

a                      b           max_val
    loc.1  [1, 2, 3, 4, 7, 5, 6]   7
    loc.2  [3, 4, 3, 7, 7, 8, 6]   8
    loc.3  [1, 4, 3, 1, 7, 8, 6]   8
    ...

Dies funktioniert jedoch nicht, da ich b.split nicht verwenden kann, da es nicht definiert ist ...

1
Alex Trevylan 17 Apr. 2018 im 20:43

3 Antworten

Beste Antwort

Wenn Sie mit Listen ohne NaN arbeiten, verwenden Sie am besten max für das Listenverständnis oder map:

a['max'] = [max(x) for x in a['b']]

a['max'] = list(map(max, a['b']))

Reine Pandas-Lösung:

a['max'] = pd.DataFrame(a['b'].values.tolist()).max(axis=1)

Probe :

array = {'loc.1': np.array([  1,2,3,4,7,5,6]),
         'loc.2': np.array([  3,4,3,7,7,8,6]),
         'loc.3': np.array([  1,4,3,1,7,8,6])}

L = [(k, v) for k, v in array.items()]
a = pd.DataFrame(L, columns=['a','b']).set_index('a')

a['max'] = [max(x) for x in a['b']]
print (a)
                           b  max
a                                
loc.1  [1, 2, 3, 4, 7, 5, 6]    7
loc.2  [3, 4, 3, 7, 7, 8, 6]    8
loc.3  [1, 4, 3, 1, 7, 8, 6]    8

BEARBEITEN:

Sie können max auch in list comprehension erhalten:

L = [(k, v, max(v)) for k, v in array.items()]
a = pd.DataFrame(L, columns=['a','b', 'max']).set_index('a')

print (a)
                           b  max
a                                
loc.1  [1, 2, 3, 4, 7, 5, 6]    7
loc.2  [3, 4, 3, 7, 7, 8, 6]    8
loc.3  [1, 4, 3, 1, 7, 8, 6]    8
3
jpp 17 Apr. 2018 im 18:49

Sie können numpy Arrays für eine vektorisierte Berechnung verwenden:

df = pd.DataFrame({'a': ['loc.1', 'loc.2', 'loc.3'],
                   'b': [[1, 2, 3, 4, 7, 5, 6],
                         [3, 4, 3, 7, 7, 8, 6],
                         [1, 4, 3, 1, 7, 8, 6]]})

df['maxval'] = np.array(df['b'].values.tolist()).max(axis=1)

print(df)

#        a                      b  maxval
# 0  loc.1  [1, 2, 3, 4, 7, 5, 6]       7
# 1  loc.2  [3, 4, 3, 7, 7, 8, 6]       8
# 2  loc.3  [1, 4, 3, 1, 7, 8, 6]       8
0
jpp 17 Apr. 2018 im 17:50

Versuche dies:

df["max_val"] = df["b"].apply(lambda x:max(x))
0
FadeoN 17 Apr. 2018 im 18:28