कॉर्पस रीडर्स और कस्टम कॉर्पोरा

कॉर्पस क्या है?

एक कॉर्पस बड़ा संग्रह है, संरचित प्रारूप में, मशीन-पठनीय ग्रंथों का जो एक प्राकृतिक संचार सेटिंग में निर्मित किया गया है। कॉर्पोरा शब्द कॉर्पस का बहुवचन है। कॉर्पस को कई तरीकों से प्राप्त किया जा सकता है -

  • पाठ से जो मूल रूप से इलेक्ट्रॉनिक था
  • बोली जाने वाली भाषा के टेप से
  • ऑप्टिकल कैरेक्टर रिकग्निशन वगैरह से

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

कस्टम कॉर्पस का निर्माण कैसे करें?

एनएलटीके डाउनलोड करते समय, हमने एनएलटीके डेटा पैकेज भी स्थापित किया। इसलिए, हमारे पास पहले से ही अपने कंप्यूटर पर एनएलटीके डेटा पैकेज स्थापित है। अगर हम विंडोज के बारे में बात करते हैं, तो हम मान लेंगे कि यह डेटा पैकेज स्थापित हैC:\natural_language_toolkit_data और अगर हम लिनक्स, यूनिक्स और मैक ओएस एक्स के बारे में बात करते हैं, तो हम मान लेंगे कि यह डेटा पैकेज स्थापित है /usr/share/natural_language_toolkit_data

निम्नलिखित पायथन रेसिपी में, हम कस्टम कॉर्पोरा बनाने जा रहे हैं जो NLTK द्वारा परिभाषित रास्तों में से एक के भीतर होना चाहिए। ऐसा इसलिए है क्योंकि यह एनएलटीके द्वारा पाया जा सकता है। आधिकारिक एनएलटीके डेटा पैकेज के साथ संघर्ष से बचने के लिए, आइए हम अपने घर की निर्देशिका में एक प्राकृतिक natural_language_toolkit_data निर्देशिका बनाएं।

import os, os.path
path = os.path.expanduser('~/natural_language_toolkit_data')
if not os.path.exists(path):
   os.mkdir(path)
os.path.exists(path)

उत्पादन

True

अब, हम जाँचते हैं कि हमारे घर की निर्देशिका में natural_language_toolkit_data निर्देशिका है या नहीं -

import nltk.data
path in nltk.data.path

उत्पादन

True

जैसा कि हमें आउटपुट ट्रू मिला है, मतलब हमारे पास है nltk_data हमारे घर निर्देशिका में निर्देशिका।

अब हम एक wordlist फाइल बनाएंगे, जिसका नाम है wordfile.txt और इसे एक फ़ोल्डर में रखा, जिसका नाम कॉर्पस इन है nltk_data निर्देशिका (~/nltk_data/corpus/wordfile.txt) और इसका उपयोग करके लोड करेगा nltk.data.load -

import nltk.data
nltk.data.load(‘corpus/wordfile.txt’, format = ‘raw’)

उत्पादन

b’tutorialspoint\n’

कॉर्पस पाठक

NLTK विभिन्न CorpusReader कक्षाएं प्रदान करता है। हम उन्हें निम्नलिखित अजगर व्यंजनों में शामिल करने जा रहे हैं

वर्डलिस्ट कॉर्पस बनाना

एनएलटीके के पास है WordListCorpusReaderवह वर्ग जो शब्दों की सूची वाली फ़ाइल तक पहुँच प्रदान करता है। निम्नलिखित पायथन नुस्खा के लिए, हमें एक वर्डलिस्ट फ़ाइल बनाने की आवश्यकता है जो सीएसवी या सामान्य पाठ फ़ाइल हो सकती है। उदाहरण के लिए, हमने 'लिस्ट' नामक एक फाइल बनाई है जिसमें निम्नलिखित डेटा हैं -

tutorialspoint
Online
Free
Tutorials

अब हमें तुरंत ए WordListCorpusReader हमारी बनाई गई फ़ाइल से शब्दों की सूची बनाने वाला वर्ग ‘list’

from nltk.corpus.reader import WordListCorpusReader
reader_corpus = WordListCorpusReader('.', ['list'])
reader_corpus.words()

उत्पादन

['tutorialspoint', 'Online', 'Free', 'Tutorials']

POS टैगिंग शब्द कोष का निर्माण

एनएलटीके के पास है TaggedCorpusReaderक्लास जिसकी मदद से हम POS टैगेड शब्द कॉर्पस बना सकते हैं। दरअसल, पीओएस टैगिंग एक शब्द के लिए पार्ट-ऑफ-स्पीच टैग की पहचान करने की प्रक्रिया है।

टैग किए गए कॉर्पस के लिए सबसे सरल स्वरूपों में से एक है 'शब्द / टैग'जैसे भूरे रंग के कोष से अंश के बाद -

The/at-tl expense/nn and/cc time/nn involved/vbn are/ber
astronomical/jj ./.

उपरोक्त अंश में, प्रत्येक शब्द में एक टैग होता है जो उसके पीओएस को दर्शाता है। उदाहरण के लिए,vb एक क्रिया को संदर्भित करता है।

अब हमें तुरंत ए TaggedCorpusReaderPOS टैग किए गए शब्दों का निर्माण करने वाला वर्ग फ़ाइल बनाता है ‘list.pos’, जिसका उपरोक्त अंश है।

from nltk.corpus.reader import TaggedCorpusReader
reader_corpus = TaggedCorpusReader('.', r'.*\.pos')
reader_corpus.tagged_words()

उत्पादन

[('The', 'AT-TL'), ('expense', 'NN'), ('and', 'CC'), ...]

मुहावरा वाक्यांश कोष बनाना

एनएलटीके के पास है ChnkedCorpusReaderकक्षा जिसकी सहायता से हम एक चुनिंदा वाक्यांश कोष बना सकते हैं। दरअसल, चंक एक वाक्य में एक छोटा वाक्यांश है।

उदाहरण के लिए, हमारे पास टैग किए गए अंश हैं treebank कॉर्पस -

[Earlier/JJR staff-reduction/NN moves/NNS] have/VBP trimmed/VBN about/
IN [300/CD jobs/NNS] ,/, [the/DT spokesman/NN] said/VBD ./.

उपर्युक्त अंश में, प्रत्येक चंक एक संज्ञा वाक्यांश है लेकिन जो शब्द कोष्ठक में नहीं हैं वे वाक्य वृक्ष का हिस्सा हैं और किसी संज्ञा वाक्यांश उप भाग का हिस्सा नहीं हैं।

अब हमें तुरंत ए ChunkedCorpusReader वर्ग फ़ाइल से chunked वाक्यांश का उत्पादन ‘list.chunk’, जिसका उपरोक्त अंश है।

from nltk.corpus.reader import ChunkedCorpusReader
reader_corpus = TaggedCorpusReader('.', r'.*\.chunk')
reader_corpus.chunked_words()

उत्पादन

[
   Tree('NP', [('Earlier', 'JJR'), ('staff-reduction', 'NN'), ('moves', 'NNS')]),
   ('have', 'VBP'), ...
]

वर्गीकृत पाठ कोष बनाना

एनएलटीके के पास है CategorizedPlaintextCorpusReaderवह वर्ग जिसकी सहायता से हम एक वर्गीकृत पाठ कोष बना सकते हैं। यह उस समय बहुत उपयोगी होता है जब हमारे पास पाठ का एक बड़ा कोष होता है और इसे अलग-अलग वर्गों में वर्गीकृत करना चाहता है।

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

from nltk.corpus import brown^M
brown.categories()

उत्पादन

[
   'adventure', 'belles_lettres', 'editorial', 'fiction', 'government',
   'hobbies', 'humor', 'learned', 'lore', 'mystery', 'news', 'religion',
   'reviews', 'romance', 'science_fiction'
]

एक कॉर्पस को वर्गीकृत करने का सबसे आसान तरीका हर श्रेणी के लिए एक फ़ाइल है। उदाहरण के लिए, हम दो अंशों को देखते हैंmovie_reviews कॉर्पस -

movie_pos.txt

पतली लाल रेखा त्रुटिपूर्ण है लेकिन यह उकसाती है।

movie_neg.txt

एक बड़ा बजट और चमकदार उत्पादन सहजता की कमी के कारण नहीं बन सकता है जो उनके टीवी शो को प्रदर्शित करता है।

इसलिए, दो फ़ाइलों के ऊपर, हमारे पास दो श्रेणियां हैं pos तथा neg

अब हमें तुरंत ए CategorizedPlaintextCorpusReader कक्षा।

from nltk.corpus.reader import CategorizedPlaintextCorpusReader
reader_corpus = CategorizedPlaintextCorpusReader('.', r'movie_.*\.txt',
cat_pattern = r'movie_(\w+)\.txt')
reader_corpus.categories()
reader_corpus.fileids(categories = [‘neg’])
reader_corpus.fileids(categories = [‘pos’])

उत्पादन

['neg', 'pos']
['movie_neg.txt']
['movie_pos.txt']