पायथन पंडों - समारोह आवेदन

पंडों की वस्तुओं के लिए अपनी खुद की या किसी अन्य पुस्तकालय के कार्यों को लागू करने के लिए, आपको तीन महत्वपूर्ण तरीकों के बारे में पता होना चाहिए। नीचे विधियों की चर्चा की गई है। उपयोग करने के लिए उपयुक्त विधि इस बात पर निर्भर करती है कि आपका फ़ंक्शन संपूर्ण 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