पायथन वेब स्क्रैपिंग - पाठ से निपटना

पिछले अध्याय में, हमने देखा है कि वेब स्क्रैपिंग सामग्री के एक भाग के रूप में प्राप्त होने वाले वीडियो और छवियों से कैसे निपटें। इस अध्याय में हम पायथन पुस्तकालय का उपयोग करके पाठ विश्लेषण से निपटने जा रहे हैं और इसके बारे में विस्तार से जानेंगे।

परिचय

आप प्राकृतिक भाषा टूल किट (NLTK) नामक पायथन लाइब्रेरी का उपयोग करके पाठ विश्लेषण कर सकते हैं। एनएलटीके की अवधारणाओं में आगे बढ़ने से पहले, हमें पाठ विश्लेषण और वेब स्क्रैपिंग के बीच के संबंध को समझना चाहिए।

पाठ में शब्दों का विश्लेषण हमें यह जानने के लिए प्रेरित कर सकता है कि कौन से शब्द महत्वपूर्ण हैं, कौन से शब्द असामान्य हैं, कैसे शब्दों को समूहबद्ध किया गया है। यह विश्लेषण वेब स्क्रैपिंग के कार्य को आसान बनाता है।

एनएलटीके के साथ शुरुआत करना

प्राकृतिक भाषा टूलकिट (एनएलटीके) पायथन पुस्तकालयों का संग्रह है जो विशेष रूप से अंग्रेजी जैसे प्राकृतिक भाषा के पाठ में पाए जाने वाले भाषण के हिस्सों की पहचान और टैगिंग के लिए डिज़ाइन किया गया है।

एनएलटीके स्थापित करना

आप Python में NLTK को स्थापित करने के लिए निम्नलिखित कमांड का उपयोग कर सकते हैं -

pip install nltk

यदि आप एनाकोंडा का उपयोग कर रहे हैं, तो एनएलटीके के लिए एक कोंडा पैकेज निम्नलिखित कमांड का उपयोग करके बनाया जा सकता है -

conda install -c anaconda nltk

एनएलटीके का डेटा डाउनलोड करना

एनएलटीके स्थापित करने के बाद, हमें प्रीसेट टेक्स्ट रिपॉजिटरी डाउनलोड करना होगा। लेकिन टेक्स्ट प्रीसेट रिपॉजिटरी डाउनलोड करने से पहले, हमें इसकी मदद से एनएलटीके आयात करना होगाimport आदेश निम्नानुसार है -

mport nltk

अब निम्नलिखित आदेश की मदद से एनएलटीके डेटा डाउनलोड किया जा सकता है -

nltk.download()

एनएलटीके के सभी उपलब्ध पैकेजों की स्थापना में कुछ समय लगेगा, लेकिन हमेशा सभी पैकेजों को स्थापित करने की सिफारिश की जाती है।

अन्य आवश्यक पैकेजों को स्थापित करना

हमें कुछ अन्य पायथन पैकेज भी चाहिए gensim तथा pattern एनएलटीके का उपयोग करके प्राकृतिक भाषा प्रसंस्करण अनुप्रयोगों के निर्माण के साथ-साथ पाठ विश्लेषण करने के लिए।

gensim- एक मजबूत सिमेंटिक मॉडलिंग लाइब्रेरी जो कई अनुप्रयोगों के लिए उपयोगी है। इसे निम्न कमांड द्वारा स्थापित किया जा सकता है -

pip install gensim

pattern - बनाने के लिए इस्तेमाल किया gensimपैकेज ठीक से काम करते हैं। इसे निम्न कमांड द्वारा स्थापित किया जा सकता है -

pip install pattern

tokenization

दिए गए पाठ को तोड़ने की प्रक्रिया को टोकन नामक छोटी इकाइयों में, टोकन कहा जाता है। ये टोकन शब्द, संख्या या विराम चिह्न हो सकते हैं। इसे कहते भी हैंword segmentation

उदाहरण

NLTK मॉड्यूल टोकन के लिए अलग पैकेज प्रदान करता है। हम अपनी आवश्यकता के अनुसार इन पैकेजों का उपयोग कर सकते हैं। कुछ पैकेज यहाँ वर्णित हैं -

sent_tokenize package- यह पैकेज इनपुट टेक्स्ट को वाक्यों में विभाजित करेगा। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.tokenize import sent_tokenize

word_tokenize package- यह पैकेज इनपुट टेक्स्ट को शब्दों में विभाजित करेगा। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.tokenize import word_tokenize

WordPunctTokenizer package- यह पैकेज इनपुट टेक्स्ट के साथ-साथ विराम चिह्नों को भी शब्दों में विभाजित करेगा। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.tokenize import WordPuncttokenizer

स्टेमिंग

किसी भी भाषा में, शब्दों के विभिन्न रूप होते हैं। एक भाषा में व्याकरणिक कारणों से बहुत सारी विविधताएं शामिल हैं। उदाहरण के लिए, शब्दों पर विचार करेंdemocracy, democratic, तथा democratization। मशीन सीखने के साथ-साथ वेब स्क्रैपिंग परियोजनाओं के लिए, मशीनों के लिए यह समझना महत्वपूर्ण है कि इन विभिन्न शब्दों का आधार आधार एक ही है। इसलिए हम कह सकते हैं कि पाठ का विश्लेषण करते समय शब्दों के आधार रूपों को निकालना उपयोगी हो सकता है।

इसे उपजी द्वारा प्राप्त किया जा सकता है जिसे शब्दों के सिरों को काटकर शब्दों के आधार रूपों को निकालने की अनुमानी प्रक्रिया के रूप में परिभाषित किया जा सकता है।

NLTK मॉड्यूल स्टेमिंग के लिए अलग पैकेज प्रदान करता है। हम अपनी आवश्यकता के अनुसार इन पैकेजों का उपयोग कर सकते हैं। इन पैकेजों में से कुछ यहाँ वर्णित हैं -

PorterStemmer package- पोर्टर के एल्गोरिथ्म का उपयोग आधार फॉर्म निकालने के लिए इस पायथन स्टेमिंग पैकेज द्वारा किया जाता है। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.stem.porter import PorterStemmer

उदाहरण के लिए, शब्द देने के बाद ‘writing’ इस स्टेमर के इनपुट के रूप में, आउटपुट शब्द होगा ‘write’ उपजी के बाद।

LancasterStemmer package- लैंकेस्टर के एल्गोरिथ्म का उपयोग बेस फॉर्म निकालने के लिए इस पायथन स्टेमिंग पैकेज द्वारा किया जाता है। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.stem.lancaster import LancasterStemmer

उदाहरण के लिए, शब्द देने के बाद ‘writing’ इस स्टेमर के इनपुट के रूप में तब आउटपुट शब्द होगा ‘writ’ उपजी के बाद।

SnowballStemmer package- स्नोबॉल के एल्गोरिथ्म का उपयोग आधार फॉर्म निकालने के लिए इस पायथन स्टेमिंग पैकेज द्वारा किया जाता है। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.stem.snowball import SnowballStemmer

उदाहरण के लिए, इस 'स्टेम' के इनपुट के रूप में 'राइटिंग' शब्द देने के बाद आउटपुट शब्द 'राइटिंग' हो जाएगा।

lemmatization

शब्दों के आधार रूप को निकालने का एक अन्य तरीका है नींबू पानी का उपयोग, आमतौर पर शब्दावली और रूपात्मक विश्लेषण का उपयोग करके विभक्ति अंत को हटाने का लक्ष्य है। लेमेट्रीकरण के बाद किसी भी शब्द के आधार रूप को लेम्मा कहा जाता है।

एनएलटीके मॉड्यूल लेमेट्रीकरण के लिए निम्नलिखित पैकेज प्रदान करता है -

WordNetLemmatizer package- यह इस आधार पर शब्द के आधार रूप को निकालेगा कि क्या यह संज्ञा के रूप में एक क्रिया के रूप में उपयोग किया जाता है। इस पैकेज को आयात करने के लिए आप निम्न कमांड का उपयोग कर सकते हैं -

from nltk.stem import WordNetLemmatizer

ठस

चुंकिंग, जिसका अर्थ है कि डेटा को छोटे-छोटे टुकड़ों में विभाजित करना, भाषण के हिस्सों और संज्ञा वाक्यांशों जैसे छोटे वाक्यांशों की पहचान करने के लिए प्राकृतिक भाषा प्रसंस्करण में महत्वपूर्ण प्रक्रियाओं में से एक है। चुंकिंग को टोकन की लेबलिंग करना है। हम प्रक्रिया की सहायता से वाक्य की संरचना प्राप्त कर सकते हैं।

उदाहरण

इस उदाहरण में, हम एनएलटीके पायथन मॉड्यूल का उपयोग करके नन-फ्रास चूनकिंग को लागू करने जा रहे हैं। NP chunking, chunking की एक श्रेणी है जो वाक्य में संज्ञा वाक्यांशों को चुनती है।

संज्ञा वाक्यांश को लागू करने के लिए कदम

हमें संज्ञा-वाक्यांश को लागू करने के लिए नीचे दिए गए चरणों का पालन करने की आवश्यकता है -

चरण 1 - चंक व्याकरण परिभाषा

पहले चरण में हम व्याकरण को मंथन के लिए परिभाषित करेंगे। इसमें उन नियमों का समावेश होगा, जिनका हमें पालन करने की आवश्यकता है।

चरण 2 - चकोर पार्सर निर्माण

अब, हम एक चकोर पार्सर बनाएंगे। यह व्याकरण को पार्स करेगा और आउटपुट देगा।

चरण 3 - आउटपुट

इस अंतिम चरण में, उत्पादन एक ट्री प्रारूप में किया जाएगा।

सबसे पहले, हमें एनएलटीके पैकेज को निम्नानुसार आयात करना होगा -

import nltk

अगला, हमें वाक्य को परिभाषित करने की आवश्यकता है। यहाँ DT: निर्धारक, VBP: क्रिया, JJ: विशेषण, IN: पूर्वसर्ग और NN: संज्ञा।

sentence = [("a", "DT"),("clever","JJ"),("fox","NN"),("was","VBP"),("jumping","VBP"),("over","IN"),("the","DT"),("wall","NN")]

अगला, हम व्याकरण को नियमित अभिव्यक्ति के रूप में दे रहे हैं।

grammar = "NP:{<DT>?<JJ>*<NN>}"

अब, कोड की अगली पंक्ति व्याकरण को पार्स करने के लिए एक पार्सर को परिभाषित करेगी।

parser_chunking = nltk.RegexpParser(grammar)

अब, पार्सर वाक्य को पार्स करेगा।

parser_chunking.parse(sentence)

अगला, हम चर में अपना आउटपुट दे रहे हैं।

Output = parser_chunking.parse(sentence)

निम्नलिखित कोड की सहायता से, हम अपने आउटपुट को एक पेड़ के रूप में आकर्षित कर सकते हैं जैसा कि नीचे दिखाया गया है।

output.draw()

वर्ड ऑफ़ बग (BoW) मॉडल निकालने और पाठ को न्यूमेरिक फॉर्म में परिवर्तित करने के लिए

बैग ऑफ वर्ड (BoW), प्राकृतिक भाषा प्रसंस्करण में एक उपयोगी मॉडल है, जिसका उपयोग मूल रूप से पाठ से सुविधाओं को निकालने के लिए किया जाता है। पाठ से सुविधाओं को निकालने के बाद, इसे मशीन लर्निंग एल्गोरिदम में मॉडलिंग में उपयोग किया जा सकता है क्योंकि कच्चे डेटा का उपयोग एमएल अनुप्रयोगों में नहीं किया जा सकता है।

BoW मॉडल का कार्य करना

प्रारंभ में, मॉडल दस्तावेज़ में सभी शब्दों से एक शब्दावली निकालता है। बाद में, दस्तावेज़ शब्द मैट्रिक्स का उपयोग करते हुए, यह एक मॉडल का निर्माण करेगा। इस तरह, BoW मॉडल केवल शब्दों के एक बैग के रूप में दस्तावेज़ का प्रतिनिधित्व करता है और आदेश या संरचना को छोड़ दिया जाता है।

उदाहरण

मान लें कि हमारे पास निम्नलिखित दो वाक्य हैं -

Sentence1 - यह बैग ऑफ वर्ड्स मॉडल का एक उदाहरण है।

Sentence2 - हम बैग्स ऑफ वर्ड्स मॉडल का उपयोग करके फीचर निकाल सकते हैं।

अब, इन दो वाक्यों पर विचार करने से, हमारे पास निम्नलिखित 14 विशिष्ट शब्द हैं -

  • This
  • is
  • an
  • example
  • bag
  • of
  • words
  • model
  • we
  • can
  • extract
  • features
  • by
  • using

एनएलटीके में शब्दों के मॉडल का एक बैग का निर्माण

आइए हम निम्नलिखित पायथन लिपि पर गौर करें जो NLTK में BoW मॉडल का निर्माण करेगी।

सबसे पहले, निम्नलिखित पैकेज आयात करें -

from sklearn.feature_extraction.text import CountVectorizer

अगला, वाक्यों के सेट को परिभाषित करें -

Sentences=['This is an example of Bag of Words model.', ' We can extract
   features by using Bag of Words model.']
   vector_count = CountVectorizer()
   features_text = vector_count.fit_transform(Sentences).todense()
   print(vector_count.vocabulary_)

उत्पादन

यह दर्शाता है कि उपरोक्त दो वाक्यों में हमारे 14 अलग-अलग शब्द हैं -

{
   'this': 10, 'is': 7, 'an': 0, 'example': 4, 'of': 9, 
   'bag': 1, 'words': 13, 'model': 8, 'we': 12, 'can': 3, 
   'extract': 5, 'features': 6, 'by': 2, 'using':11
}

टॉपिक मॉडलिंग: टेक्स्ट डेटा में पैटर्न की पहचान करना

आम तौर पर दस्तावेजों को विषयों में वर्गीकृत किया जाता है और विषय मॉडलिंग एक पाठ में पैटर्न की पहचान करने की एक तकनीक है जो किसी विशेष विषय से मेल खाती है। दूसरे शब्दों में, विषय मॉडलिंग का उपयोग किसी दिए गए दस्तावेज़ में सार विषयों या छिपी संरचना को उजागर करने के लिए किया जाता है।

आप निम्नलिखित परिदृश्य में विषय मॉडलिंग का उपयोग कर सकते हैं -

पाठ वर्गीकरण

विषय मॉडलिंग द्वारा वर्गीकरण में सुधार किया जा सकता है क्योंकि यह प्रत्येक शब्द को एक फीचर के रूप में अलग-अलग उपयोग करने के बजाय समान शब्दों को एक साथ रखता है।

अनुशंसा प्रणाली

हम समानता उपायों का उपयोग करके सिफारिशकर्ता प्रणाली का निर्माण कर सकते हैं।

विषय मॉडलिंग एल्गोरिदम

हम निम्नलिखित एल्गोरिदम का उपयोग करके विषय मॉडलिंग को लागू कर सकते हैं -

Latent Dirichlet Allocation(LDA) - यह सबसे लोकप्रिय एल्गोरिथ्म में से एक है जो विषय मॉडलिंग को लागू करने के लिए संभाव्य चित्रमय मॉडल का उपयोग करता है।

Latent Semantic Analysis(LDA) or Latent Semantic Indexing(LSI) - यह रेखीय बीजगणित पर आधारित है और दस्तावेज़ अवधि मैट्रिक्स पर एसवीडी (विलक्षण मूल्य अपघटन) की अवधारणा का उपयोग करता है।

Non-Negative Matrix Factorization (NMF) - यह भी एलडीए की तरह रैखिक बीजगणित पर आधारित है।

उपर्युक्त एल्गोरिदम में निम्नलिखित तत्व होंगे -

  • विषयों की संख्या: पैरामीटर
  • दस्तावेज़-शब्द मैट्रिक्स: इनपुट
  • डब्ल्यूटीएम (वर्ड टॉपिक मैट्रिक्स) और टीडीएम (टॉपिक डॉक्यूमेंट मैट्रिक्स): आउटपुट