A full Python package that allows users to search for a Wiki article, scrape it and have features for text analytics.
Please feel free to download the script file for personal usage! (wikiscrape.py)
New Graph Plots of the years mentioned in a Wikipedia Article:
New Graph of plotting the most popular words in a Wikipedia Article:
To save a wikiscrape object, simply type:
import wikiscrape
var = wikiscrape.wiki('Search Article')
e.g. paris = wikiscrape.wiki('PArIs','Yes','french','Yes','Yes') means to search for the article Paris, auto format to proper case (Yes for 2nd argument, default Yes), search for French wikipedia (french for 3rd argument, default English), apply nltk stoplist for french (Yes for 4th argument, default No) and lemmatize the article using nltk (Yes for 5th argument, default No)
- Able to search in multiple languages
- Give suggestions on search terms if search is ambiguous
- Gives a short summary (2 paragraphs) of the article if it is retrieved successfully
- Retrieve full text or exact number of paragraphs in string output for data pipeline
- var.HELP() for the full list of functions available
- Basic error handling, including checking data type of arguments and reverting to defaults if errorneous args are given
- Apply local stoplist by directly editing the dictionary, and also applying NLTK stoplist for multiple languages
- Lemmatizing the article before using the text analytics functions
- A frequency counter on the most common words in the Wikipedia article (after omitting common English words, or stoplist from NLTK for foreign languages). Can also find the Nth % of most common words, where 0 =< N =< 100.
- A graph plot of the most common words in the Wikipedia article, and save the graph as an image
- A graph plot on the most frequent Years mentioned in the article, to understand the Years of interest of the article, and save the graph as an image
- A summary on the total number of words and total number of unique words after implementing the stoplist & lemmatization of common words.
- Analytics functions available in wikiscrape object are commonwords, commonwordspct, plotwords, plotyear, totalwords, summary, gettext.
Refer to images in the repository for examples. The earliest image 'bar.png' made 4 months ago was the initial design for the bar chart for word frequency. Examples of the newest images (last edit: 27 Nov 2019) are 'ColdplayWordCount2.png' and 'Donald_Trump_40words.png'.
Libraries used: requests, bs4, collections, matplotlib, re, os, math, datetime, nltk (optional, only if using stoplist or lemmatization)
Refer to requirements.txt
Package itself already has a comprehensive stoplist built inside to remove common words before text analytics
- 26 May 2019 - Added plotyear() function to plot the most frequent years mentioned, and removed years in the frequency count of word counter (commonwords & commonwordspct functions).
- 9 June 2019 - Added markdown for explanation and added comments in the code for understanding
- 13 June 2019 - Updated documentation for plotyear, plotwords, summary and gettext function in .HELP().
- 25 November 2019 - Update coming very soon to patch issues and improve on Wikipedia package, stay tuned!
- 27 November 2019 - Major update to the Python package, including:
a. Adding of lemmatization feature (using NLTK) before using text analytics functions
b. Better documentation via docstrings and updating HELP function
c. Improving of graph plotting design and font size for plotwords and plotyear
d. Fixed some bugs for graph plotting including values not showing or showing up erroneously
e. Refactored the code, provided better names for key variables for user understanding
f. Performance improvement of article search by removing unused variables and functions
g. Tested all functions and also error handling in case user puts in wrong parameters - 09 May 2020 - New feature to exclude N number of latest years in plotwords (e.g. from current year 2020, 2019, ...) and made graph titles larger
- For any questions or suggestions, please contact me at my Linkedin account - https://www.linkedin.com/in/kohjiaxuan/