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 | Training Unigram Tagger
- NLP | Training Tagger Based Chunker | Set 1
- NLP | Named Entity Chunker Training
- NLP | Training Tagger Based Chunker | Set 2
- Python | Pokémon Training Game
- ML | Training Image Classifier using Tensorflow Object Detection API
- NLP | Filtering Insignificant Words
- Python | Bilateral Filtering
- Implementing Artificial Neural Network training process in Python
- Filtering Images based on size attributes in Python
- Python | Filtering data with Pandas .query() method
- Python | Reverse each word in a sentence
- Python | Remove all duplicates words from a given sentence
- Python | Spilt a sentence into list of words
If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to email@example.com. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.