Git Product home page Git Product logo

smmt's Introduction

Social Media Mining Toolkit (SMMT)

Aphrodite Sticker The set of tools collected and presented here are designed with the purpose of facilitating the acquisition, preprocessing, and initial exploration of social media data (mostly Twitter for now). This centralized repository depends on other widely available libraries that need to be installed.

We separated this toolkit in three categories (each one on an individual folder):

1. Data Acquisition Tools: Utilities to gather data from social media sites
2. Data Preprocessing Tools: Utilities to parse social media 'raw' data and to separate by terms
3. Data Annotation and Standardization Tools: Utilities to make automatic NER annotations on preprocessed tweets, plugins to use popular annotation tools and NER systems

Usage

  1. Install dependencies (below)
  2. Clone repository
  3. Make sure you have your Twitter API keys handy if you are gathering any Twitter Data
  4. Each tool and their usage is described on the README file on each category of tools folder.

All the libraries used in this toolkit can be installed using the following command.

sh requirements.sh

Note: If you would like to setup headless browsing automation tasks, please install additional dependencies given below.

Dependencies and versions used

  1. Python 3+

  2. Spacy v2.2

pip install spacy 
python -m spacy download en
python -m spacy download en_core_web_sm
  1. Twarc pip install twarc

  2. Tweepy v3.8.0 pip install tweepy

  3. argparse - v3.2 pip install argparse

  4. xtract - v0.1a3 pip install xtract

NOTE: If you are using the scraping utility, install the following dependencies. These dependencies are needed for the headless browsing automation tasks (no need to have a screen open for them). Configuration of these items is very finicky but there is plenty of documentation online.

  1. Xvf sudo yum install Xvfb

  2. Firefox sudo yum install firefox

  3. selenium pip install -U selenium

  4. pyvirtualdisplay - v0.25 pip install pyvirtualdisplay

  5. GeckoDriver - v0.26.0 sudo yum install jq

and then use the provided utility:

bash SMMT/data_acquisition/geckoDriverInstall.sh

If you still have issues or the Firefox window is popping up through your X11, follow this: https://www.tienle.com/2016/09-20/run-selenium-firefox-browser-centos.html

Twitter Keys

This is a very important step, if you do not have any Twitter API keys, none of the software that uses Twitter API will work without it

How to cite our work:

If you used SMMT and liked it, please cite the following paper:

R Tekumalla and JM Banda. "Social Media Mining Toolkit (SMMT)". Genomics & Informatics, 18, (2), 2020. https://doi.org/10.5808/GI.2020.18.2.e16

Social Media Mining Toolkit (SMMT) Extra Information

Data Acquisition Tools:

  1. Twitter hydration tool - This script will hydrate tweet ID’s provided by others.
  2. Twitter gathering tool - This script will allow users to specify hashtags and capture from the twitter faucet new tweets with the given hashtag.

Data Preprocessing Tools:

  1. Twitter JSON extraction tool - While seemingly trivial, most biomedical researchers do not want to work with JSON objects. This tool will take the fields the researcher wants and output a simple to use CSV file created from the provided data.

Data Annotation and Standardization Tools:

  1. Spacy dictionary-based annotation pipeline This is the tool that will require the most work during the hackathon. This pipeline will be available as a service as well, with the user providing their dictionaries and feeding data directly.
  2. Dictionary generation tool This tool will transform ontologies or provided dictionary files into spacy compliant dictionaries to use with the previous pipeline.
  3. Manual annotation hooks to tools like brat annotation tools

This work was conceptualized for/and (mostly) carried out while at the Biomedical Linked Annotation Hackathon 6 in Tokyo, Japan.

BLAH

We are very grateful for the support on this work.

Proposed functionality of SMMT V1.0

Architecture

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.