Python Pandalar - Uyarılar ve Gotchalar
Uyarılar uyarı anlamına gelir ve aldatma, görünmeyen bir sorun anlamına gelir.
Pandalar ile If / Truth İfadesini Kullanma
Pandalar, bir şeyi bir bool. Bu birif veya when Boolean işlemlerini kullanarak ve, orveya not. Sonucun ne olması gerektiği belli değil. Sıfır uzunlukta olmadığı için Doğru mu olmalı? Yanlış çünkü Yanlış değerler var mı? Belirsizdir, dolayısıyla Pandalar birValueError -
import pandas as pd
if pd.Series([False, True, False]):
print 'I am True'
Onun output aşağıdaki gibidir -
ValueError: The truth value of a Series is ambiguous.
Use a.empty, a.bool() a.item(),a.any() or a.all().
İçinde ifdurum, onunla ne yapılacağı belli değil. Hata, birNone veya any of those.
import pandas as pd
if pd.Series([False, True, False]).any():
print("I am any")
Onun output aşağıdaki gibidir -
I am any
Bir Boole bağlamında tek öğeli panda nesnelerini değerlendirmek için yöntemi kullanın .bool() -
import pandas as pd
print pd.Series([True]).bool()
Onun output aşağıdaki gibidir -
True
Bitsel Boole
== ve gibi Bitsel Boole operatörleri != Neredeyse her zaman gerekli olan bir Boole dizisi döndürür.
import pandas as pd
s = pd.Series(range(5))
print s==4
Onun output aşağıdaki gibidir -
0 False
1 False
2 False
3 False
4 True
dtype: bool
isin Operasyonu
Bu, Serideki her öğenin tam olarak geçirilen değerler dizisinde yer alıp almadığını gösteren bir Boole dizisi döndürür.
import pandas as pd
s = pd.Series(list('abc'))
s = s.isin(['a', 'c', 'e'])
print s
Onun output aşağıdaki gibidir -
0 True
1 False
2 True
dtype: bool
Yeniden dizin oluşturma ve ix Gotcha
Birçok kullanıcı kendilerini ix indexing capabilities bir Pandas nesnesinden veri seçmenin özlü bir yolu olarak -
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(6, 4), columns=['one', 'two', 'three',
'four'],index=list('abcdef'))
print df
print df.ix[['b', 'c', 'e']]
Onun output aşağıdaki gibidir -
one two three four
a -1.582025 1.335773 0.961417 -1.272084
b 1.461512 0.111372 -0.072225 0.553058
c -1.240671 0.762185 1.511936 -0.630920
d -2.380648 -0.029981 0.196489 0.531714
e 1.846746 0.148149 0.275398 -0.244559
f -1.842662 -0.933195 2.303949 0.677641
one two three four
b 1.461512 0.111372 -0.072225 0.553058
c -1.240671 0.762185 1.511936 -0.630920
e 1.846746 0.148149 0.275398 -0.244559
Bu, elbette, bu durumda tamamen reindex yöntem -
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(6, 4), columns=['one', 'two', 'three',
'four'],index=list('abcdef'))
print df
print df.reindex(['b', 'c', 'e'])
Onun output aşağıdaki gibidir -
one two three four
a 1.639081 1.369838 0.261287 -1.662003
b -0.173359 0.242447 -0.494384 0.346882
c -0.106411 0.623568 0.282401 -0.916361
d -1.078791 -0.612607 -0.897289 -1.146893
e 0.465215 1.552873 -1.841959 0.329404
f 0.966022 -0.190077 1.324247 0.678064
one two three four
b -0.173359 0.242447 -0.494384 0.346882
c -0.106411 0.623568 0.282401 -0.916361
e 0.465215 1.552873 -1.841959 0.329404
Bazıları şu sonuca varabilir: ix ve reindexbuna göre% 100 eşdeğerdir. Bu, tamsayı indeksleme durumu dışında geçerlidir. Örneğin, yukarıdaki işlem alternatif olarak şu şekilde ifade edilebilir -
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(6, 4), columns=['one', 'two', 'three',
'four'],index=list('abcdef'))
print df
print df.ix[[1, 2, 4]]
print df.reindex([1, 2, 4])
Onun output aşağıdaki gibidir -
one two three four
a -1.015695 -0.553847 1.106235 -0.784460
b -0.527398 -0.518198 -0.710546 -0.512036
c -0.842803 -1.050374 0.787146 0.205147
d -1.238016 -0.749554 -0.547470 -0.029045
e -0.056788 1.063999 -0.767220 0.212476
f 1.139714 0.036159 0.201912 0.710119
one two three four
b -0.527398 -0.518198 -0.710546 -0.512036
c -0.842803 -1.050374 0.787146 0.205147
e -0.056788 1.063999 -0.767220 0.212476
one two three four
1 NaN NaN NaN NaN
2 NaN NaN NaN NaN
4 NaN NaN NaN NaN
Bunu hatırlamak önemlidir reindex is strict label indexing only. Bu, bir indeksin, örneğin hem tam sayıları hem de dizeleri içerdiği patolojik durumlarda bazı potansiyel olarak şaşırtıcı sonuçlara yol açabilir.