Community Data Science Workshops (Fall 2014)/Day 2 lecture: Difference between revisions

From OpenHatch wiki
Content added Content deleted
imported>Fhocutt
mNo edit summary
imported>Mako
No edit summary
 
(8 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{CDSW Moved}}

[[File:Highfivekitten.jpeg|200px|thumb|In which you learn how to use Python and web APIs to meet the likes of her!]]
== Lecture Slides ==

* [http://mako.cc/teaching/2014/cdsw-autumn/lecture2-web_apis.pdf Slides (PDF)] — For viewing
* [http://mako.cc/teaching/2014/cdsw-autumn/lecture2-web_apis.odp Slides (ODP Libreoffice Slides Format)] — For editing and modification
== Resources ==

* Encoding:
** [http://nedbatchelder.com/text/unipain.html Pragmatic Unicode]
** [https://docs.python.org/2/howto/unicode.html Official Python Unicode documentation]


== Lecture Outline ==
== Lecture Outline ==
;Introduction and context
;Introduction and context

* You can write some tools in Python now. Congratulations!
* You can write some tools in Python now. Congratulations!
* Today we'll learn how to find/create data sets
* Today we'll learn how to find/create data sets
* Next week we'll get into data science (asking and answering questions)
* Next week we'll get into data science (asking and answering questions)



;Outline:
;Outline:

* What did we learn in Session 1?
* What did we learn in Session 1?
* What is an API?
* What is an API?
Line 13: Line 30:
* Introduction to structured data (JSON)
* Introduction to structured data (JSON)
* How do we use APIs in general?
* How do we use APIs in general?



;What is a (web) API?
;What is a (web) API?

* API: a structured way for programs to talk to each other (aka an interface for programs)
* API: a structured way for programs to talk to each other (aka an interface for programs)
* Web APIs: like a website your programs can visit (you:a website::your program:a web API)
* Web APIs: like a website your programs can visit (you:a website::your program:a web API)



; How do we use an API to fetch datasets?
; How do we use an API to fetch datasets?

Basic idea: your program sends a request, the API sends data back
Basic idea: your program sends a request, the API sends data back
* Where do you direct your request? The site's API endpoint.
* Where do you direct your request? The site's API endpoint.
Line 31: Line 52:
** There's a module for that!
** There's a module for that!



; What did we learn in Session 1?
; How do we write Python programs that make web requests?

To use APIs to build a dataset we will need:
* all our tools from last session: variables, etc
* the ability to open urls on the web
* the ability to create custom URLS
* the ability to save to files
* the ability to understand (i.e., parse) JSON data that APIs usually give us


; Session 1 review

* Navigating in the terminal and using it to run programs
* Navigating in the terminal and using it to run programs
* Writing Python:
* Writing Python:
Line 41: Line 74:
** importing modules, so you can use code other people have written for you!
** importing modules, so you can use code other people have written for you!


; How do we write Python programs that make web requests?


New programming concepts:
; New programming concepts:

* requests
* interpolate variables into a string using % and %()s
* interpolate variables into a string using % and %()s
* requests
* open files and write to them
* open files and write to them
* parsing a string (turning the string into a data structure we can manipulate)


* to use APIs to build a dataset we will need:
** all our tools from last session: variables, etc
** the ability to open urls on the web
** the ability to create custom URLS
** the ability to save to files
** the ability to understand (i.e., parse) JSON data that APIs usually give us


; How do we use an API to fetch kitten pictures?
; How do we use an API to fetch kitten pictures?

[http://placekitten.com/ placekitten.com]
[http://placekitten.com/ placekitten.com]
* API that takes specially crafted URLs and gives appropriately sized picture of kittens
* API that takes specially crafted URLs and gives appropriately sized picture of kittens
* example of placekitten in browser
* Exploring placekitten in a browser:
** visit the API documentation
** visit the API documentation
** kittens of different sizes
** kittens of different sizes
** kittens in greyscale or color
** kittens in greyscale or color
* Now we write a small program to grab an arbitrary square from placekitten by asking for the size on standard in: [http://mako.cc/teaching/2014/cdsw-autumn/placekitten_raw_input.py placekitten_raw_input.py]
* show how to use place

* write a small program to grab arbitrary square from placekitten by asking for the size on standard in

; Introduction to structured data (JSON, JavaScriptObjectNotation)


; Introduction to structured data (JSON)
* what is json: useful for more structured data
JSON file (JavaScript Object Notation)
* what is json: useful for more structure data
* import json; json.loads()
* import json; json.loads()
* like Python (except no single quotes)
* like Python (except no single quotes)
Line 73: Line 102:
* can reflect more complicated data structures
* can reflect more complicated data structures
* Example file at http://mako.cc/cdsw.json
* Example file at http://mako.cc/cdsw.json
* download it and parse it
* download it and parse it: [http://mako.cc/teaching/2014/cdsw-autumn/parse_cdswjson.py parse_cdswjson.py]



; Using other APIs
; Using other APIs

* every API is different, so read the documentation!
* every API is different, so read the documentation!
* If the documentation isn't helpful, search online!
* If the documentation isn't helpful, search online
* for popular APIs, there are python modules that help you make requests and parse json!
* for popular APIs, there are python modules that help you make requests and parse json

Possible issues:
* rate limiting
* rate limiting
* authentication
* authenticaiton
* text encoding issues
* text encoding issues

Latest revision as of 22:05, 15 March 2015

Page Moved
All material related to the Community Data Science Workshops have been moved from the OpenHatch wiki to a new dedicated wiki and this page is no longer being updated here. Please visit the new version of the page on the Community Data Science Collective wiki.
In which you learn how to use Python and web APIs to meet the likes of her!

Lecture Slides

Resources


Lecture Outline

Introduction and context
  • You can write some tools in Python now. Congratulations!
  • Today we'll learn how to find/create data sets
  • Next week we'll get into data science (asking and answering questions)


Outline
  • What did we learn in Session 1?
  • What is an API?
  • How do we use one to fetch interesting datasets?
  • How do we write programs that use the internet?
  • How can we use the placekitten API to fetch kitten pictures?
  • Introduction to structured data (JSON)
  • How do we use APIs in general?


What is a (web) API?
  • API: a structured way for programs to talk to each other (aka an interface for programs)
  • Web APIs: like a website your programs can visit (you:a website::your program:a web API)


How do we use an API to fetch datasets?

Basic idea: your program sends a request, the API sends data back

  • Where do you direct your request? The site's API endpoint.
  • How do I write my request? Put together a URL; it will be different for different web APIs.
    • Check the documentation, look for code samples
  • How do you send a request?
    • Python has modules you can use, like requests (they make HTTP requests)
  • What do you get back?
    • Structured data (usually in the JSON format)
  • How do you understand (i.e. parse) the data?
    • There's a module for that!


How do we write Python programs that make web requests?

To use APIs to build a dataset we will need:

  • all our tools from last session: variables, etc
  • the ability to open urls on the web
  • the ability to create custom URLS
  • the ability to save to files
  • the ability to understand (i.e., parse) JSON data that APIs usually give us


Session 1 review
  • Navigating in the terminal and using it to run programs
  • Writing Python:
    • using variables to manipulate data
    • types of data: strings, integers, lists, dictionaries
    • if statements
    • for loops
    • printing
    • importing modules, so you can use code other people have written for you!


New programming concepts
  • interpolate variables into a string using % and %()s
  • requests
  • open files and write to them
  • parsing a string (turning the string into a data structure we can manipulate)


How do we use an API to fetch kitten pictures?

placekitten.com

  • API that takes specially crafted URLs and gives appropriately sized picture of kittens
  • Exploring placekitten in a browser:
    • visit the API documentation
    • kittens of different sizes
    • kittens in greyscale or color
  • Now we write a small program to grab an arbitrary square from placekitten by asking for the size on standard in: placekitten_raw_input.py


Introduction to structured data (JSON, JavaScriptObjectNotation)
  • what is json: useful for more structured data
  • import json; json.loads()
  • like Python (except no single quotes)
  • simple lists, dictionaries
  • can reflect more complicated data structures
  • Example file at http://mako.cc/cdsw.json
  • download it and parse it: parse_cdswjson.py


Using other APIs
  • every API is different, so read the documentation!
  • If the documentation isn't helpful, search online
  • for popular APIs, there are python modules that help you make requests and parse json

Possible issues:

  • rate limiting
  • authentication
  • text encoding issues