Why do we need to train a sentence tokenizer?
In NLTK, default sentence tokenizer works for the general purpose and it works very well. But there are chances that it won’t work best for some kind of text as that text may use nonstandard punctuation or maybe it is having a unique format. So, to handle such cases, training sentence tokenizer can result in much more accurate sentence tokenization.
Let us consider the following text for the understanding of the concept. This kind of text is very common in case of any web text corpus.
Example of TEXT: A guy: So, what are your plans for the party? B girl: well! I am not going! A guy: Oh, but u should enjoy.
To download text file, click here.
Code #1 : Training Tokenizer
'White guy: So, do you have any plans for this evening?' 'Hobo: Got any spare change?'
Code #2: Default Sentence Tokenizer
'White guy: So, do you have any plans for this evening?' 'Girl: But you already have a Big Mac...\r\nHobo: Oh, this is all theatrical.'
This difference in the second output is a good demonstration of why it can be useful to train your own sentence tokenizer, especially when your text isn’t in the typical paragraph-sentence structure.
How training works ?
PunktSentenceTokenizer class follows an unsupervised learning algorithm to learn what constitutes a sentence break. It is unsupervised because so one need not give any labelled training data, just raw text.
Filtering stopwords in a tokenized sentence
Stopwords are common words that are present in the text but generally do not contribute to the meaning of a sentence. They hold almost no importance for the purposes of information retrieval and natural language processing. For example – ‘the’ and ‘a’. Most search engines will filter out stop words from search queries and documents.
NLTK library comes with a stopwords corpus –
nltk_data/corpora/stopwords/ that contains word lists for many languages.
Code #3 : Stopwords with Python
Before stopwords removal: ["Let's", 'see', 'how', "it's", 'working'] After stopwords removal : ["Let's", 'see', 'working'] ?
Code #4 : Complete list of languages used in NLTK stopwords.
['danish', 'dutch', 'english', 'finnish', 'french', 'german', 'hungarian', 'italian', 'norwegian', 'portuguese', 'russian', 'spanish', 'swedish', 'turkish']
- Python NLTK | nltk.tokenizer.word_tokenize()
- NLP | Filtering Insignificant Words
- NLP | Training Unigram Tagger
- NLP | Named Entity Chunker Training
- NLP | Training Tagger Based Chunker | Set 1
- NLP | Training Tagger Based Chunker | Set 2
- Python | Filtering data with Pandas .query() method
- Filtering Images based on size attributes in Python
- ML | Training Image Classifier using Tensorflow Object Detection API
- Implementing Artificial Neural Network training process in Python
- Python | Reverse each word in a sentence
- Python program to count words in a sentence
- NLP | How tokenizing text, sentence, words works
- Python | Spilt a sentence into list of words
- Python | Remove all duplicates words from a given sentence