building a data science toolbox

69
Building a Jeroen Janssens @jeroenhjanssens

Upload: jeroen-janssens

Post on 11-Aug-2014

1.268 views

Category:

Data & Analytics


4 download

DESCRIPTION

The *nix command line, although invented decades ago, is an amazing environment for doing data science. By combining small, yet powerful, command-line tools we can really explore our data and quickly hack together prototypes. The recent addition of tools such as GNU Parallel, jq, and, Drake, further enables us to be more productive and more efficient data scientists. Installing these command-line tools and setting up an efficient environment is, unfortunately, not straightforward. In the first part of this talk I will desribe how the command line can be used for doing data science. The focus will be common operation regarding obtaining, scrubbing, and exploring data. I will walk through an example where we scrape a data set from a Wikipedia page using more modern command-line tools. In the second part I will present a new open-source project called the Data Science Toolbox (http://datasciencetoolbox.org), which is a virtual environment that allows you to get started doing data science in minutes. It comes with commonly used software for data science and allows for easy installation of additional tools. Because the Data Science Toolbox runs on top of VirtualBox, it can be installed not only on Linux, but also on Mac OS X and Microsoft Windows. Once you have a solid environment, it is worthwhile to further customize it to your own needs. In the third part of the talk I will explain how to (1) make your environment more efficient and (2) create reusable command-line tools from one-off commands or from existing code in, for example, Python and R. By the end of this talk you will have a solid understanding of how to leverage the power of the command line for your next data science project.

TRANSCRIPT

Page 1: Building a Data Science Toolbox

Building a

Jeroen Janssens@jeroenhjanssens

Page 2: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Overview

- Data science at the command line

- Data Science Toolbox

- Building your own data science toolbox

Building a Data Science Toolbox Jeroen Janssens

Page 3: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Data Science at theCommand Line

Building a Data Science Toolbox Jeroen Janssens

Page 4: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Data science is OSEMN

- Obtaining data

- Scrubbing data

- Exploring data

- Modeling data

- iNterpreting data

Building a Data Science Toolbox Jeroen Janssens

Page 5: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Command line on Mac OS X

Building a Data Science Toolbox Jeroen Janssens

Page 6: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Command line on Ubuntu

Building a Data Science Toolbox Jeroen Janssens

Page 7: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

The command line is awesome

- Play with your data (REPL)

- Combine tools

- Many tools available

- Automatable

- Many servers run GNU/Linux

- One overarching environment

Building a Data Science Toolbox Jeroen Janssens

Page 8: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Essential Tools andConcepts

Building a Data Science Toolbox Jeroen Janssens

Page 9: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Command-line tool is an umbrella term

- Executable

- Script

- One-liner

- Shell command

- Shell function

- Alias

Building a Data Science Toolbox Jeroen Janssens

Page 10: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Unix philosophy

Write command-line tools that:

- Do one thing and do it well

- Work together

- Handle text streams

Building a Data Science Toolbox Jeroen Janssens

Page 11: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Tips dataset$ cat tips.csvbill,tip,sex,smoker,day,time,size16.99,1.01,Female,No,Sun,Dinner,210.34,1.66,Male,No,Sun,Dinner,321.01,3.5,Male,No,Sun,Dinner,323.68,3.31,Male,No,Sun,Dinner,224.59,3.61,Female,No,Sun,Dinner,425.29,4.71,Male,No,Sun,Dinner,48.77,2.0,Male,No,Sun,Dinner,226.88,3.12,Male,No,Sun,Dinner,415.04,1.96,Male,No,Sun,Dinner,214.78,3.23,Male,No,Sun,Dinner,210.27,1.71,Male,No,Sun,Dinner,235.26,5.0,Female,No,Sun,Dinner,4

Building a Data Science Toolbox Jeroen Janssens

Page 12: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Reference manual$ man catCAT(1) User Commands CAT(1)

NAMEcat - concatenate files and print on the standardoutput

SYNOPSIScat [OPTION]... [FILE]...

DESCRIPTIONConcatenate FILE(s), or standard input, to standard output.

-A, --show-allequivalent to -vET

Building a Data Science Toolbox Jeroen Janssens

Page 13: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Looking at files$ cat tips.csv | csvlook|--------+------+--------+--------+------+--------+-------|| bill | tip | sex | smoker | day | time | size ||--------+------+--------+--------+------+--------+-------|| 16.99 | 1.01 | Female | No | Sun | Dinner | 2 || 10.34 | 1.66 | Male | No | Sun | Dinner | 3 || 21.01 | 3.5 | Male | No | Sun | Dinner | 3 || 23.68 | 3.31 | Male | No | Sun | Dinner | 2 || 24.59 | 3.61 | Female | No | Sun | Dinner | 4 || 25.29 | 4.71 | Male | No | Sun | Dinner | 4 || 8.77 | 2.0 | Male | No | Sun | Dinner | 2 || 26.88 | 3.12 | Male | No | Sun | Dinner | 4 || 15.04 | 1.96 | Male | No | Sun | Dinner | 2 || 14.78 | 3.23 | Male | No | Sun | Dinner | 2 |

Building a Data Science Toolbox Jeroen Janssens

Page 14: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Looking at files$ cat tips.csv | less$ cat tips.csv | head -n 3 | csvlook|--------+------+--------+--------+-----+--------+-------|| bill | tip | sex | smoker | day | time | size ||--------+------+--------+--------+-----+--------+-------|| 16.99 | 1.01 | Female | No | Sun | Dinner | 2 || 10.34 | 1.66 | Male | No | Sun | Dinner | 3 ||--------+------+--------+--------+-----+--------+-------|$ < tips.csv tail -n 3 | csvlook -H|--------+------+--------+-----+------+--------+----|| 22.67 | 2.0 | Male | Yes | Sat | Dinner | 2 || 17.82 | 1.75 | Male | No | Sat | Dinner | 2 || 18.78 | 3.0 | Female | No | Thur | Dinner | 2 ||--------+------+--------+-----+------+--------+----|

Building a Data Science Toolbox Jeroen Janssens

Page 15: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Filtering lines$ grep 'Lunch' tips.csv | csvlook -H|--------+------+--------+-----+------+-------+----|| 27.2 | 4.0 | Male | No | Thur | Lunch | 4 || 22.76 | 3.0 | Male | No | Thur | Lunch | 2 || 17.29 | 2.71 | Male | No | Thur | Lunch | 2 || 19.44 | 3.0 | Male | Yes | Thur | Lunch | 2 || 16.66 | 3.4 | Male | No | Thur | Lunch | 2 || 10.07 | 1.83 | Female | No | Thur | Lunch | 1 || 32.68 | 5.0 | Male | Yes | Thur | Lunch | 2 || 15.98 | 2.03 | Male | No | Thur | Lunch | 2 || 34.83 | 5.17 | Female | No | Thur | Lunch | 4 || 13.03 | 2.0 | Male | No | Thur | Lunch | 2 || 18.28 | 4.0 | Male | No | Thur | Lunch | 2 || 24.71 | 5.85 | Male | No | Thur | Lunch | 2 |

Building a Data Science Toolbox Jeroen Janssens

Page 16: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Filtering lines$ cat tips.csv | awk -F, '$7 !~ /[1-4]/' | csvlook|--------+------+--------+--------+------+--------+-------|| bill | tip | sex | smoker | day | time | size ||--------+------+--------+--------+------+--------+-------|| 29.8 | 4.2 | Female | No | Thur | Lunch | 6 || 34.3 | 6.7 | Male | No | Thur | Lunch | 6 || 41.19 | 5.0 | Male | No | Thur | Lunch | 5 || 27.05 | 5.0 | Female | No | Thur | Lunch | 6 || 29.85 | 5.14 | Female | No | Sun | Dinner | 5 || 48.17 | 5.0 | Male | No | Sun | Dinner | 6 || 20.69 | 5.0 | Male | No | Sun | Dinner | 5 || 30.46 | 2.0 | Male | Yes | Sun | Dinner | 5 || 28.15 | 3.0 | Male | Yes | Sat | Dinner | 5 ||--------+------+--------+--------+------+--------+-------|

Building a Data Science Toolbox Jeroen Janssens

Page 17: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Filtering lines$ csvgrep -c size -r "[1-4]" -i tips.csv | csvlook|--------+------+--------+--------+------+--------+-------|| bill | tip | sex | smoker | day | time | size ||--------+------+--------+--------+------+--------+-------|| 29.8 | 4.2 | Female | No | Thur | Lunch | 6 || 34.3 | 6.7 | Male | No | Thur | Lunch | 6 || 41.19 | 5.0 | Male | No | Thur | Lunch | 5 || 27.05 | 5.0 | Female | No | Thur | Lunch | 6 || 29.85 | 5.14 | Female | No | Sun | Dinner | 5 || 48.17 | 5.0 | Male | No | Sun | Dinner | 6 || 20.69 | 5.0 | Male | No | Sun | Dinner | 5 || 30.46 | 2.0 | Male | Yes | Sun | Dinner | 5 || 28.15 | 3.0 | Male | Yes | Sat | Dinner | 5 ||--------+------+--------+--------+------+--------+-------|

Building a Data Science Toolbox Jeroen Janssens

Page 18: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Extracting columns$ csvgrep -c size -r "[1-4]" -i tips.csv > size56.csv$ cut size56.csv -d, -f1,2bill,tip29.8,4.234.3,6.741.19,5.027.05,5.029.85,5.1448.17,5.020.69,5.030.46,2.028.15,3.0

Building a Data Science Toolbox Jeroen Janssens

Page 19: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Extracting columns$ awk -F, '{print $1","$2}' size56.csvbill,tip29.8,4.234.3,6.741.19,5.027.05,5.029.85,5.1448.17,5.020.69,5.030.46,2.028.15,3.0

Building a Data Science Toolbox Jeroen Janssens

Page 20: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Extracting columns$ csvcut size56.csv -c bill,tipbill,tip29.8,4.234.3,6.741.19,5.027.05,5.029.85,5.1448.17,5.020.69,5.030.46,2.028.15,3.0

Building a Data Science Toolbox Jeroen Janssens

Page 21: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Extracting words$ curl -s 'http://www.gutenberg.org/cache/epub/76/pg76.txt'|> tee finn | grep -oE '\w+' | tee wordsTheProjectGutenbergEBookofAdventuresofHuckleberryFinnCompletebyMark

Building a Data Science Toolbox Jeroen Janssens

Page 22: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Sorting and counting$ wc finn12361 114266 610157 finn

$ < words grep '^a' | grep 'e$' | sort | uniq -c | sort -rn77 are21 alone20 ashore19 above13 alive9 awhile9 apiece7 axe7 agree5 anywhere

Building a Data Science Toolbox Jeroen Janssens

Page 23: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Replacing data$ < finn tr '[a-z]' '[A-Z]' > /dev/null$ < finn tr '[:lower:]' '[:upper:]' | head -n 14

THE PROJECT GUTENBERG EBOOK OF ADVENTURES OF HUCKLEBERRY FINN, COMPLETEBY MARK TWAIN (SAMUEL CLEMENS)

THIS EBOOK IS FOR THE USE OF ANYONE ANYWHERE AT NO COST AND WITH ALMOSTNO RESTRICTIONS WHATSOEVER. YOU MAY COPY IT, GIVE IT AWAY OR RE-USEIT UNDER THE TERMS OF THE PROJECT GUTENBERG LICENSE INCLUDED WITH THISEBOOK OR ONLINE AT WWW.GUTENBERG.NET

TITLE: ADVENTURES OF HUCKLEBERRY FINN, COMPLETE

AUTHOR: MARK TWAIN (SAMUEL CLEMENS)

Building a Data Science Toolbox Jeroen Janssens

Page 24: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Replacing data$ < finn sed 's/ /_/g' | head -n 14

The_Project_Gutenberg_EBook_of_Adventures_of_Huckleberry_Finn,_Completeby_Mark_Twain_(Samuel_Clemens)

This_eBook_is_for_the_use_of_anyone_anywhere_at_no_cost_and_with_almostno_restrictions_whatsoever._You_may_copy_it,_give_it_away_or_re-useit_under_the_terms_of_the_Project_Gutenberg_License_included_with_thiseBook_or_online_at_www.gutenberg.net

Title:_Adventures_of_Huckleberry_Finn,_Complete

Author:_Mark_Twain_(Samuel_Clemens)

Building a Data Science Toolbox Jeroen Janssens

Page 25: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Summing values$ < tips.csv | tail -n +2 | cut -d, -f1 | paste -s -d+16.99+10.34+21.01+23.68+24.59+25.29+8.77+26.88+15.04+14.78+10.27+35.26+15.42+18.43+14.83+21.58+10.33+16.29+16.97+20.65+17.92+20.29+15.77+39.42+19.82+17.81+13.37+12.69+21.7+19.65+9.55+18.35+15.06+20.69+17.78+24.06+16.31+16.93+18.69+ ...

$ < tips.csv | tail -n +2 | cut -d, -f1 | paste -s -d+ | bc4827.77

$ < tips.csv awk -F, '{ sum+=$1} END {print sum}'4827.77

$ < tips.csv Rio -e 'sum(df$bill)'[1] 4827.77

Building a Data Science Toolbox Jeroen Janssens

Page 26: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Example: Web Scraping

Building a Data Science Toolbox Jeroen Janssens

Page 27: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Extracting data from HTML

Building a Data Science Toolbox Jeroen Janssens

Page 28: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Download HTML using curl$ curl -s 'http://en.wikipedia.org/wiki/List_of_countries_and_territories_by_border/area_ratio'<!DOCTYPE html><html lang="en" dir="ltr" class="client-nojs"><head><meta charset="UTF-8" /><title>List of countries and territories by border/area ratio - Wikipedia, the free encyclopedia</title><meta name="generator" content="MediaWiki 1.23wmf10" /><link rel="alternate" type="application/x-wiki" title="Edit this page" href="/w/index.php?title=List_of_countries_and_territories_by_border/area_ratio&amp;action=edit" /><link rel="edit" title="Edit this page" href="/w/index.php?title=List_of_countries_and_territories_by_border/area_ratio&amp;action=edit" /><link rel="apple-touch-icon" href="//bits.wikimedia.org/apple-touch/wikipedia.png" /><link rel="shortcut icon" href="//bits.wikimedia.org/favicon/wikipedia.ico" /><link rel="search" type="application/opensearchdescription+xml" href="/w/opensearch_desc.php" title="Wikipedia (en)" /><link rel="EditURI" type="application/rsd+xml" href="//en.wikipedia.org/w/api.php?action=rsd" /><link rel="copyright" href="//creativecommons.org/licenses/by-sa/3.0/" />

Building a Data Science Toolbox Jeroen Janssens

Page 29: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Scrape element with CSS selectors

$ < wiki.html scrape -b -e 'table.wikitable > \> tr:not(:first-child)'<!DOCTYPE html><html><body><tr><td>1</td><td>Vatican City</td><td>3.2</td><td>0.44</td><td>7.2727273</td></tr>

Building a Data Science Toolbox Jeroen Janssens

Page 30: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Convert to JSON using xml2json$ < table.html xml2json | jq '.'{"html": {

"body": {"tr": [

{"td": [

{"$t": "1"

},{"$t": "Vatican City"

},

Building a Data Science Toolbox Jeroen Janssens

Page 31: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Transform JSON using jq

$ < table.json jq -c '.html.body.tr[] | {country: .td[1][],> border: .td[2][], surface: .td[3][], ratio: .td[4][]}'{"ratio":"7.2727273","surface":"0.44","border":"3.2","country":"Vatican City"}{"ratio":"2.2000000","surface":"2","border":"4.4","country":"Monaco"}{"ratio":"0.6393443","surface":"61","border":"39","country":"San Marino"}{"ratio":"0.4750000","surface":"160","border":"76","country":"Liechtenstein"}{"ratio":"0.3000000","surface":"34","border":"10.2","country":"Sint Maarten (Netherlands)"}{"ratio":"0.2570513","surface":"468","border":"120.3","country":"Andorra"}{"ratio":"0.2000000","surface":"6","border":"1.2","country":"Gibraltar (United Kingdom)"}{"ratio":"0.1888889","surface":"54","border":"10.2","country":"Saint Martin (France)"}{"ratio":"0.1388244","surface":"2586","border":"359","country":"Luxembourg"}{"ratio":"0.0749196","surface":"6220","border":"466","country":"Palestinian territories"}

Building a Data Science Toolbox Jeroen Janssens

Page 32: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Convert to CSV with json2csv$ < countries.json json2csv -p -k border,surface | csvlook|----------+-----------|| border | surface ||----------+-----------|| 3.2 | 0.44 || 4.4 | 2 || 39 | 61 || 76 | 160 || 10.2 | 34 || 120.3 | 468 || 1.2 | 6 || 10.2 | 54 || 359 | 2586 || 466 | 6220 |

Building a Data Science Toolbox Jeroen Janssens

Page 33: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Behold, the beast

$ curl -s 'http://en.wikipedia.org/wiki/List_of_countries> _and_territories_by_border/area_ratio' |> scrape -be 'table.wikitable > tr:not(:first-child)' |> xml2json | jq -c '.html.body.tr[] | {country: .td[1][],> border: .td[2][], surface: .td[3][], ratio: .td[4][]}' |> json2csv -p -k=border,surface | csvlook

Building a Data Science Toolbox Jeroen Janssens

Page 34: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Exploration

Building a Data Science Toolbox Jeroen Janssens

Page 35: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Statistics at the command line$ < tips.csv tail -n +2 | cut -d, -f2 | qstatsMin. 11st Qu. 2Median 2.9Mean 2.998283rd Qu. 3.575Max. 10Range 9Std Dev. 1.3808Length 244

$ < tips.csv | tail -n +2 | cut -d, -f2 | qstats -m2.99828

Building a Data Science Toolbox Jeroen Janssens

Page 36: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Statistics at the command line$ < tips.csv tail -n +2 | cut -d, -f2 | histogram.py -b10NumSamples = 244; Min = 1.00; Max = 10.00Mean = 2.998279; Variance = 1.906609; SD = 1.380800each * represents a count of 11.0000 - 1.9000 [41]: *****************************************1.9000 - 2.8000 [79]: *******************************************************************************2.8000 - 3.7000 [66]: ******************************************************************3.7000 - 4.6000 [27]: ***************************4.6000 - 5.5000 [19]: *******************5.5000 - 6.4000 [ 5]: *****6.4000 - 7.3000 [ 4]: ****7.3000 - 8.2000 [ 1]: *8.2000 - 9.1000 [ 1]: *9.1000 - 10.0000 [ 1]: *

Building a Data Science Toolbox Jeroen Janssens

Page 37: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Rio: Making R part of the pipeline

$ < tips.csv Rio -se 'sqldf("select time,count(*) from> df group by time;")'time,count(*)Dinner,176Lunch,68

Building a Data Science Toolbox Jeroen Janssens

Page 38: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Rio: Making R part of the pipeline

$ < tips.csv Rio -se 'sqldf("select time,count(*) from> df group by time;")'time,count(*)Dinner,176Lunch,68

$ < tips.csv | csvcut -c time | tail -n+2 | sort | uniq -c176 Dinner68 Lunch

Building a Data Science Toolbox Jeroen Janssens

Page 39: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

ggplot at the command line$ < tips.csv Rio -ge 'g+geom_point(aes(total_bill,tip,> colour=sex))+facet_wrap(~ time)' | display

Building a Data Science Toolbox Jeroen Janssens

Page 40: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Data Science Toolbox

Building a Data Science Toolbox Jeroen Janssens

Page 41: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Motivation

- Writing Data Science at the Command Line

- Isolated environment for executing code

- Share environment with readers

- Shell script to install command-line tools

- Turn shell script into more generic solution

Building a Data Science Toolbox Jeroen Janssens

Page 42: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Data Science Toolbox 0.1.5

- Virtual environment for data science

- Locally and in the cloud

- Open source (BSD license)

- http://datasciencetoolbox.org

- @DataSciToolbox

Building a Data Science Toolbox Jeroen Janssens

Page 43: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Standing on the shoulders of giants

Building a Data Science Toolbox Jeroen Janssens

Page 44: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Sensible base

Data Science Toolbox currently contains:

- Python scientific stack

- R

- dst command-line tool

Building a Data Science Toolbox Jeroen Janssens

Page 45: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Software and data bundles

Collection of software and/or data related to:

- Book

- Course

- Organization

Building a Data Science Toolbox Jeroen Janssens

Page 46: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Software and data bundles

Building a Data Science Toolbox Jeroen Janssens

Page 47: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Locally or in the cloud?

- Locally

- Need to share resources- No internet connection needed- Completely free

- In the cloud

- Larger machines possible- Probably not free- Long running experiments

Building a Data Science Toolbox Jeroen Janssens

Page 48: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Getting Started(See also http://datasciencetoolbox.org)

Building a Data Science Toolbox Jeroen Janssens

Page 49: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Download and install VirtualBox and Vagrant

- https://www.virtualbox.org/wiki/Downloads

- http://www.vagrantup.com/downloads.html

Building a Data Science Toolbox Jeroen Janssens

Page 50: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Download and start the Data Science Toolbox

Create directory:$ mkdir MyDataScienceToolbox$ cd MyDataScienceToolbox

Download and start:$ vagrant init data-science-toolbox/dst$ vagrant up

Building a Data Science Toolbox Jeroen Janssens

Page 51: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Log inOn Mac OS X and Linux:$ vagrant ssh

On Microsoft Windows:

- Download putty.exe- Enter:

- Host Name (or IP address): 127.0.0.1- Port: 2222- Connection type: SSH

- Username and password: vagrantBuilding a Data Science Toolbox Jeroen Janssens

Page 52: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Install additional software and bundles

Ubuntu and Python packages:vagrant@data-science-toolbox:~$ sudo apt-get install cowsayvagrant@data-science-toolbox:~$ sudo pip install networkx

R packages:vagrant@data-science-toolbox:~$ R

> install.packages('stringr')

Bundles:vagrant@data-science-toolbox:~$ dst add dsatcl

Building a Data Science Toolbox Jeroen Janssens

Page 53: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Building your own DataScience Toolbox

Building a Data Science Toolbox Jeroen Janssens

Page 54: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Optimizing your environment

- Terminal, shell, and prompt

- Aliases, functions, and scripts

- Shortcuts

Building a Data Science Toolbox Jeroen Janssens

Page 55: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Custom terminal, shell, and prompt

Building a Data Science Toolbox Jeroen Janssens

Page 56: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Aliasesalias l '/bin/ls -ltrFsA'alias mi 'mv -i'alias up "cd .."alias fox "open -a 'Firefox' \!:*"

# spelling while typing is hardalias alais aliasalias moer morealias mroe morealias pu up

#alias onion 'open http://www.theonion.com/content/index'alias onion echo "back to work"

Building a Data Science Toolbox Jeroen Janssens

Page 57: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Shortcuts

$ cd ~/some/very/deep/often-used/directory$ mark deep

$ jump deep

$ unmark deep

$ marksdeep -> /home/jeroen/some/very/deep/often-used/directoryfoo -> /usr/bin/foo/bar

Building a Data Science Toolbox Jeroen Janssens

Page 58: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Shortcutsexport MARKPATH=$HOME/.marksfunction mark {

mkdir -p "$MARKPATH"; ln -s "$(pwd)" "$MARKPATH/$1"}function jump {

cd -P "$MARKPATH/$1" 2>/dev/null ||echo "No such mark: $1"

}function unmark {

rm -i "$MARKPATH/$1"}function marks {

ls -l "$MARKPATH" | sed 's/ / /g' |cut -d' ' -f9- | sed 's/ -/\t-/g' && echo

}Building a Data Science Toolbox Jeroen Janssens

Page 59: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

From one-liners to reusable tools

- Shebang: #!/usr/bin/env bash

- Permission: chmod +x

- Arguments: $1, $2, $@

- Exit codes: 0, 1, 2

- Extension is not important

- Add to PATH

Building a Data Science Toolbox Jeroen Janssens

Page 60: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Example: CLI for explainshell.com

Building a Data Science Toolbox Jeroen Janssens

Page 61: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Example: CLI for explainshell.com

#!/usr/bin/env bash# explain: Command-line wrapper for explainshell.com## Example usage: explain tar xzvf# Dependency: scrape# Author: http://jeroenjanssens.com

COMMAND="$@"URL="http://explainshell.com/explain?cmd=${COMMAND}"curl -s "${URL}" |scrape -e 'span.dropdown > a, pre' |sed -re 's/<(\/?)[^>]*>//g'

Building a Data Science Toolbox Jeroen Janssens

Page 62: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Example: CLI for explainshell.com$ explain tar xzvfThe GNU version of the tar archiving utility

-x, --extract, --getextract files from an archive

-z, --gzip, --gunzip --ungzip

-v, --verboseverbosely list files processed

-f, --file ARCHIVEuse archive file or device ARCHIVE

Building a Data Science Toolbox Jeroen Janssens

Page 63: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Command-line tools from existing code

- Accept standard input

- Write to standard output / error

- Parse command-line arguments

- Provide help

- Take Unix philosophy into account

Building a Data Science Toolbox Jeroen Janssens

Page 64: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Parsing command-line arguments with docopt#!/usr/bin/env python"""Usage: pycho [-hnv] [STRING ...]

-h --help Show this screen.-n Do not output trailing newline.-v --version Show version."""from docopt import docoptfrom sys import stdoutif __name__ == "__main__":

args = docopt(__doc__, version="Pycho 1.0")stdout.write(" ".join(args["STRING"]))if not args["-n"]:

stdout.write("\n")

Building a Data Science Toolbox Jeroen Janssens

Page 65: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Parsing command-line arguments with docopt$ pycho -hUsage: pycho [-hnv] [STRING ...]

-h --help Show this screen.-n Do not output trailing newline.-v --version Show version.

$ pycho --versionPycho 1.0

$ pycho -n COMMAND LINE REPRESENTCOMMAND LINE REPRESENT%

$

Building a Data Science Toolbox Jeroen Janssens

Page 66: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Conclusion

- Data Science Toolbox lets you start doing datascience in minutes

- Command line is great for doing data science

- Does not solve all your problems

- OK to continue with R / IPython / ...

Building a Data Science Toolbox Jeroen Janssens

Page 67: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Where to go from here?

- Install Data Science Toolbox

- Do a tutorial

- Practice your one-liners

- Give (feed)back

Building a Data Science Toolbox Jeroen Janssens

Page 68: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

References

- http://datasciencetoolbox.org

- http://cli.learncodethehardway.org/book/

- https://github.com/tonyfischetti/qstats

- https://github.com/jehiah/json2csv

- https://github.com/bitly/data_hacks

- https://github.com/chrishwiggins/mise

- http://csvkit.readthedocs.org/en/latest/

- http://stedolan.github.io/jq/

Building a Data Science Toolbox Jeroen Janssens

Page 69: Building a Data Science Toolbox

. . . . . . . . . . . . . . . . . . . . . . . . . . . . .Data Science at the Command Line

. . . . . . . . . . . .Data Science Toolbox

. . . . . . . . .Building your own Data Science Toolbox

Thank you!

[email protected]://jeroenjanssens.com

@jeroenhjanssens

Building a Data Science Toolbox Jeroen Janssens