पायथन पंडों - समारोह आवेदन
पंडों की वस्तुओं के लिए अपनी खुद की या किसी अन्य पुस्तकालय के कार्यों को लागू करने के लिए, आपको तीन महत्वपूर्ण तरीकों के बारे में पता होना चाहिए। नीचे विधियों की चर्चा की गई है। उपयोग करने के लिए उपयुक्त विधि इस बात पर निर्भर करती है कि आपका फ़ंक्शन संपूर्ण DataFrame, पंक्ति- या स्तंभ-वार या तत्व-वार पर संचालित होने की अपेक्षा करता है या नहीं।
- टेबल वार समारोह आवेदन: पाइप ()
- पंक्ति या स्तंभ वार फ़ंक्शन अनुप्रयोग: लागू करें ()
- तत्व वार समारोह आवेदन: आवेदन पत्र ()
टेबल-वार फ़ंक्शन अनुप्रयोग
समारोह और पाइप तर्कों के रूप में उपयुक्त मापदंडों को पारित करके कस्टम संचालन किया जा सकता है। इस प्रकार, ऑपरेशन पूरे DataFrame पर किया जाता है।
उदाहरण के लिए, DataFrame में सभी तत्वों के लिए एक मान 2 जोड़ें। फिर,
योजक समारोह
योजक फ़ंक्शन पैरामीटर के रूप में दो संख्यात्मक मान जोड़ता है और योग देता है।
def adder(ele1,ele2):
return ele1+ele2
अब हम डेटाफ़्रेम पर ऑपरेशन करने के लिए कस्टम फ़ंक्शन का उपयोग करेंगे।
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.pipe(adder,2)
आइये देखते हैं पूरा कार्यक्रम -
import pandas as pd
import numpy as np
def adder(ele1,ele2):
return ele1+ele2
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.pipe(adder,2)
print df.apply(np.mean)
आईटी इस output इस प्रकार है -
col1 col2 col3
0 2.176704 2.219691 1.509360
1 2.222378 2.422167 3.953921
2 2.241096 1.135424 2.696432
3 2.355763 0.376672 1.182570
4 2.308743 2.714767 2.130288
पंक्ति या स्तंभ वार फ़ंक्शन अनुप्रयोग
डेटा का उपयोग करते हुए डेटाफ़्रेम या पैनल के अक्षों के साथ मनमाना कार्य लागू किया जा सकता है apply()विधि, जो वर्णनात्मक सांख्यिकी विधियों की तरह, एक वैकल्पिक अक्ष तर्क लेती है। डिफ़ॉल्ट रूप से, ऑपरेशन कॉलम-वार को निष्पादित करता है, प्रत्येक कॉलम को एक सरणी की तरह लेता है।
उदाहरण 1
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.apply(np.mean)
print df.apply(np.mean)
आईटी इस output इस प्रकार है -
col1 -0.288022
col2 1.044839
col3 -0.187009
dtype: float64
पास करके axis पैरामीटर, संचालन पंक्ति वार किया जा सकता है।
उदाहरण 2
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.apply(np.mean,axis=1)
print df.apply(np.mean)
आईटी इस output इस प्रकार है -
col1 0.034093
col2 -0.152672
col3 -0.229728
dtype: float64
उदाहरण 3
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.apply(lambda x: x.max() - x.min())
print df.apply(np.mean)
आईटी इस output इस प्रकार है -
col1 -0.167413
col2 -0.370495
col3 -0.707631
dtype: float64
तत्व समझदार कार्य अनुप्रयोग
सभी कार्यों को वेक्टर नहीं किया जा सकता है (न ही NumPy सरणियां जो किसी अन्य सरणी और न ही किसी भी मान को लौटाती हैं), विधियाँ applymap() DataFrame पर और analogously map() सीरीज़ में किसी भी पायथन फ़ंक्शन को एक मान लेते हैं और एक एकल मान वापस करते हैं।
उदाहरण 1
import pandas as pd
import numpy as np
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
# My custom function
df['col1'].map(lambda x:x*100)
print df.apply(np.mean)
आईटी इस output इस प्रकार है -
col1 0.480742
col2 0.454185
col3 0.266563
dtype: float64
उदाहरण 2
import pandas as pd
import numpy as np
# My custom function
df = pd.DataFrame(np.random.randn(5,3),columns=['col1','col2','col3'])
df.applymap(lambda x:x*100)
print df.apply(np.mean)
आईटी इस output इस प्रकार है -
col1 0.395263
col2 0.204418
col3 -0.795188
dtype: float64