Stopword filtering is a common step in preprocessing text for various purposes. This is a list of several different stopword lists extracted from various search engines, libraries, and articles. There's a surprising number of different lists.
At the moment it's just English stopwords.
file | size | source | description |
---|---|---|---|
None | 0 | ⇱ | No stop word removal. |
Galago (forumstop) | 15 | ⇱ | Short list of forum slang. Included in the Lemur project. |
EBSCOhost | 24 | ⇱ | The stop words used in EBSCOhost medical databases MEDLINE and CINAHL |
CoreNLP (Hardcoded) | 28 | ⇱ | Hardcoded in src/edu/stanford/nlp/coref/data/WordLists.java and the same in src/edu/stanford/nlp/dcoref/Dictionaries.java |
Ranks NL (Google) | 32 | ⇱ | The short stopwords list below is based on what we believed to be Google stopwords a decade ago, based on words that were ignored if you would search for them in combination with another word. (ie. as in the phrase "a keyword"). |
Lucene, Solr, Elastisearch | 33 | ⇱ | (NOTE: Some config files have extra 's' and 't' as stopwords.) An unmodifiable set containing some common English words that are not usually useful for searching. |
MySQL (InnoDB) | 36 | ⇱ | A word that is used by default as a stopword for FULLTEXT indexes on InnoDB tables. Not used if you override the default stopword processing with either the innodb_ft_server_stopword_table or the innodb_ft_user_stopword_table option. |
Ovid (Medical information services) | 39 | ⇱ | Words of little intrinsic meaning that occur too frequently to be useful in searching text are known as "stopwords." You cannot search for the following stopwords by themselves, but you can include them within phrases. |
Bow (libbow, rainbow, arrow, crossbow) | 48 | ⇱ | Bow: A Toolkit for Statistical Language Modeling, Text Retrieval, Classification and Clustering. Short list hardcoded. Also includes 524 SMART derived list, same as MALLET. See http://www.cs.cmu.edu/~mccallum/bow/rainbow/ |
LingPipe | 76 | ⇱ | An EnglishStopTokenizerFactory applies an English stop list to a contained base tokenizer factory |
Vowpal Wabbit (doc2lda) | 83 | ⇱ | Stopwords used in LDA example |
Text Analytics 101 | 85 | ⇱ | Minimal list compiled by Kavita Ganesan consisting of determiners, coordinating conjunctions and prepositions http://text-analytics101.rxnlp.com/2014/10/all-about-stop-words-for-text-mining.html |
LexisNexis® | 100 | ⇱ | “The following are 'noise words' and are never searchable: EVER HARDLY HENCE INTO NOR WERE VIZ. Others are 'noisy keywords' and are searchable by enclosing them in quotes.” |
Okapi (gsl.cacm) | 108 | ⇱ | Cacm specific stoplist from Okapi |
TextFixer | 119 | ⇱ | From textfixer.com Linked from Wiki page on Stop words. |
DKPro | 127 | ⇱ | Postgresql (Snowball derived) |
Postgres | 127 | ⇱ | “Stop words are words that are very common, appear in almost every document, and have no discrimination value.” |
CoreNLP (Acronym) | 150 | ⇱ | A set of words that should be considered stopwords for the acronym matcher |
NLTK | 153 | ⇱ | According to email Van Rij. Sbergen (1979) "Information retrieval" (Butterworths, London). It's slightly expanded from postgres postgresql.txt which was borrowed from snowball presumably. |
Spark ML lib | 153 | ⇱ | (Note: Same as NLTK) They were obtained from postgres The English list has been augmented |
MongoDB | 174 | ⇱ | Commit says 'Changed stop words files to the snowball stop lists' |
Quanteda | 174 | ⇱ | Has SMART and Snowball Default Lists. Source |
Ranks NL (Default) | 174 | ⇱ | (Note: Same as Default Snowball Stoplist, but RanksNL frequently cited as source) “This list is used in [Ranks NL] Page Analyzer and Article Analyzer for English text, when you let it use the default stopwords list.” |
Snowball (Original) | 174 | ⇱ | Default Snowball Stoplist. |
Xapian | 174 | ⇱ | (Note: uses Snowball Stopwords) “It has been traditional in setting up IR systems to discard the very commonest words of a language - the stopwords - during indexing.” |
99webTools | 183 | ⇱ | “Stop Words are words which do not contain important significance to be used in Search Queries. Most search engine filters these words from search query before performing search, this improves performance.” |
Reuters Web of Science™ | 211 | ⇱ | “Stopwords are common, frequently used words such as articles (a, an, the), prepositions (of, in, for, through), and pronouns (it, their, his) that cannot be searched as individual words in the Topic and Title fields. If you include a stopword in a phrase, the stopword is interpreted as a word placeholder.” |
Function Words (Cook 1988) | 221 | ⇱ | “This list of 225 items was compiled for practical purposes some time ago as data for a computer parser for student English. Paper |
Okapi (gsl.sample) | 222 | ⇱ | This Okapi is the BM25 Okapi. (Note: Included stopword text file is from all “F” “H” terms, as defined by defs.h) The GSL file contains terms that are to be dealt with in a special way by the indexing process. Each type is defined by a class code. |
Snowball (Expanded) | 227 | ⇱ | NOTE: This Includes the extra words mentioned in comments “An English stop word list. Many of the forms below are quite rare (e.g. 'yourselves') but included for completeness.” |
* Galago (stopStructure) | 246 | ⇱ | Phrases that could be useful to filter from queries like “where can i find stuff about” |
DataScienceDojo | 250 | ⇱ | Used in a real-time sentiment AzureML demo for a meetup |
CoreNLP (stopwords.txt) | 257 | ⇱ | Note: "a", "an", "the", "and", "or", "but", "nor" hardcoded in StopList.java also includes punctuation (!!, -lrb- …) |
OkapiFramework | 262 | ⇱ | THIS IS NOT Okapi of BM25! (At least I don't think so) This list used in Okapi FRAMEWORK this Okapi is the Localization and Translation Okapi. |
ATIRE (NCBI Medline) | 313 | ⇱ | NCBI wrd_stop stop word list of 313 terms extracted from Medline. Its use is unrestricted. The list can be downloaded from here |
scikit-learn | 318 | ⇱ | Uses Glasgow list, but without the word “computer” |
Glasgow IR | 319 | ⇱ | Linguistic resources from Glasgow Information Retrieval group. Lots of copies and edits of this one. Eg: xpo6 has mistakes – has quote instead of 'lf' eg: herse" instead of herself - comes up as one of the top results in google search. |
* Function Words (Gilner, Morales 2005) | 324 | ⇱ | (NOTE: Some of these are ngrams like "each other" or "in view of". Quantifiers are included, edited in - but are incomplete: eg: numbers “one” to “ten” only, “half”, “third” to “tenth” etc. See original files for explanation. May not work as a drop in replacement!) Lists of the function words in the English language. Auxiliary Verbs, Conjunctions, Determiners, Prepositions, Pronouns, Quantifiers. |
Gensim | 339 | ⇱ | Same as spaCy (Improved list from Stone, Denis, Kwantes (2010)) |
Okapi (Expanded gsl.cacm) | 339 | ⇱ | Expanded cacm list from Okapi |
spaCy | 339 | ⇱ | Improved list from Stone, Denis, Kwantes (2010) Paper |
C99 and TextTiling | 371 | ⇱ | UIMA wrapper for the java implementations of the segmentation algorithms C99 and TextTiling, written by Freddy Choi |
Galago (inquery) | 418 | ⇱ | The core/src/main/resources/stopwords/inquery list is same as Indri default. |
Indri | 418 | ⇱ | Part of Lemur Project |
Onix, Lextek | 429 | ⇱ | This stopword list is probably the most widely used stopword list. It covers a wide number of stopwords without getting too aggressive and including too many words which a user might search upon. This wordlist contains 429 words. |
GATE (Keyphrase Extraction) | 452 | ⇱ | Stopwords used in GATE Keyphrase Extraction Algorithm |
Zettair | 469 | ⇱ | Zettair is a compact and fast text search engine designed and written by the Search Engine Group at RMIT University. It was once known as Lucy. |
Okapi (Expanded gsl.sample) | 474 | ⇱ | Same as okapi_sample.txt but with “I” terms (not default Okapi behaviour! but may be useful) |
Taporware | 485 | ⇱ | TAPoRware Project, McMaster University - modified Glasgow list – includes numbers 0 to 100, and 1990 to 2020 (for dates presumably) also punctuation |
Voyant (Taporware) | 488 | ⇱ | Voyant uses taporware list by default, includes extra thou, thee, thy – presumably for Shakespeare corpus. Trombone repo also has Glasgow and SMART in resources. |
MALLET | 524 | ⇱ | Default MALLET stopword list. (Based on SMART I think) See Docs |
Weka | 526 | ⇱ | Like Bow (Rainbow, which is SMART) but with extra ll ve added to avoid words like you'll,I've etc. Almost exactly the same as mallet.txt |
MySQL (MyISAM) | 543 | ⇱ | MyISAM and InnoDB use different stoplists. Taken from SMART but modified |
Galago (rmstop) | 565 | ⇱ | Includes some punctuation, utf8 characters, www, http, org, net, youtube, wikipedia |
SMART | 571 | ⇱ | SMART (System for the Mechanical Analysis and Retrieval of Text) Information Retrieval System is an information retrieval system developed at Cornell University in the 1960s. |
ROUGE | 598 | ⇱ | Extended SMART list used in ROUGE 1.5.5 Summary Evaluation Toolkit – includes extra words: reuters, ap, news, tech, index, 3 letter days of the week and months. |
Ranks NL (Large) | 667 | ⇱ | A very long list from ranks.nl |
Terrier | 733 | ⇱ | Terrier Retrieval Engine “Stopword list to load can be loaded from the stopwords.filename property.” |
ATIRE (Puurula) | 988 | ⇱ | Included in ATIRE See Paper |
Notes:
- Entries with * could contain ngrams, not just single words. May not work the way you'd expect.
- File format: 1 word per line. Unix newlines
\n
, end with a blank line. utf8 encoded. - Case & Punctuation was preserved as presented, except when all UPPERCASE - these were lowercased.
- Where multiple versions of lists exist in code, the latest stable version was used.
- Exact duplicates included for reference (eg: MongoDB). Linked to the file i found first.
- Source URL is where the word list came from. Sometimes listed words do not match what's in the software.
- Description includes a note or how the page, help manuals, or code comments describe stopwords.
- There are way too many other blog posts and pages that list english stopwords, and many more are hardcoded in different implementations. I tried finding the most prominent ones (well known tools, or linked from Wiki, or first result on Google, or from IR / NLP researchers).
- build.py generates this file with table above from en_stopwords.csv
- Visualise differences and overlaps
- Find and cite original papers that introduced specific lists
- Influence on retrieval: How much can be attributed to just stopwords. Is it significant? Lets find out.
-
http://www.cs.uml.edu/~haim/teaching/iws/tirsaa/sources/text_utilities.html
-
http://text-analytics101.rxnlp.com/2014/10/all-about-stop-words-for-text-mining.html
-
https://github.com/lintool/IR-Reproducibility/tree/master/systems
-
http://www.umiacs.umd.edu/~oard/teaching/734/fall15/software.html
-
Galago also has a "stop phrase" list: https://sourceforge.net/p/lemur/galago/ci/default/tree/core/src/main/resources/stopwords/stopStructure
-
SMART FTP Mirror: http://ftp.gnome.org/mirror/archive/ftp.sunet.se/pub/databases/full-text/smart/
-
Multiple language stopwords (EN already one of the above in table): https://sites.google.com/site/kevinbouge/stopwords-lists
-
More for multiple languages (EN already one of the above in table): https://code.google.com/archive/p/stop-words/
-
Stopwords for 50 languages in json (EN is SMART): https://github.com/6/stopwords-json
Have you got a favourite stopword list that's different to what's here? Send a pull request with your list as a text file, 1 word per line in en/ folder and a new row in en_stopwords.csv