Philadelphia Python Workshop/Projects: Difference between revisions

no edit summary
imported>Geography76
(Created page with "Welcome to the Saturday afternoon projects section of the Chicago Python Workshop! After lunch, we'll break out into groups to practice Python through using the Twitter API to...")
 
imported>Maneesha
No edit summary
 
(12 intermediate revisions by 2 users not shown)
Line 1:
Welcome to the Saturday afternoon projects section of the ChicagoPhiladelphia Python Workshop! After lunch, we'll break out into groups to practice Python through using the Twitter API to write the basic parts of a Twitter client. We'll also work through a WordPlay exercise to practice manipulating and matching strings.
 
 
==Setup==
 
See the [[ChicagoPhiladelphia Python Workshop/Setup#Goal_.236:_get_dependencies_installed_for_the_Saturday_projects|Friday setup instructions]].
==Twitter==
 
<table>
<tr>
<td>
[[File:Twitter.png|100px]]<br />
<center><b>Twitter</b></center>
</td>
<td>
Use the Twitter API to write the basic parts of a Twitter client. See what your friends are tweeting, get trending topics, search tweets, and more.
</td>
</tr>
</table>
===Twitter goals===
 
* practice for loops
* practice using functions
* practice implementing functions
* see what it's like to use an API
* have fun collecting data from Twitter
 
===Concept review===
 
====Indentation reminder====
 
In Python, indentation matters. Everything is indented by a multiple
of some number of spaces, often 4.
 
In <code>if</code> statements, you indent everything you want to be run if the if
conditional is <code>True</code>. For example:
 
<pre>
>>> James = 35
>>> Alice = 30
>>> if James > Alice:
... print "James is older than Alice."
...
James is older than Alice.
>>></pre>
 
Because James really is older than Alice, the <code>if</code> conditional is <code>True</code>,
so Python does execute the code indented under the if line. In this
case we print "James is older than Alice."
 
<pre>
>>> James = 35
>>> Alice = 30
>>> if James < Alice:
... print "James is younger than Alice."
...
>>></pre>
 
Because James is not older than Alice, the <code>if</code> conditional is <code>False</code>, so
Python does not execute the code indented under the if line.
 
In for loops, you indent everything you want to be run each loop For
example:
 
<pre>
>>> names = ["Jessica", "Adam", "Liz"]
>>> for name in names:
... print "Hello " + name
...
Hello Jessica
Hello Adam
Hello Liz</pre>
 
The <code>print</code> line is indented 4 spaces under the <code>for</code>. That's how
Python knows to execute the print line for every name in names.
 
====Functions====
 
Let's review what we know about functions:
 
* They do some useful bit of work.
* They let us re-use code without having to type it out each time.
* They take input and possibly produce output (we say they return a value). You can assign a variable to this output.
* You define a function using the def keyword.
* You call a function by using its name followed by its arguments in parenthesis.
 
Here's an example:
 
<pre>
>>> def add(x, y):
... return x + y
...
>>> add(1, 2)
3
>>> add(-1, 1)
0
>>> add(.5, .75)
1.25</pre>
 
====pass====
 
<code>pass</code> is a keyword that just means "do nothing". It most often shows up
as a place-holder for code that doesn't exist yet. For example:
 
<pre>
>>> def testFunction():
... pass
...
>>></pre>
 
====Imports====
 
Imports look like this:
 
<pre>
>>> import random
>>> import time</pre>
 
In the above example, <code>random</code> and <code>time</code> are both Python modules. Modules
are Python files outside of the current Python file that contain
Python code, like functions and variables. You can use code from
modules by first importing the module. Here's an example from the
<code>random</code> module:
 
<pre>
>>> import random
>>> random.randint(0, 10)
7
>>> random.randint(0, 10)
6
>>> random.randint(0, 10)
1
>>> random.randint(0, 10)
3
>>> random.randint(0, 10)
4
>>> random.randint(0, 10)
9</pre>
 
<code>randint</code> is a function in the <code>random</code> module. It takes a lower bound as
the first argument and an upper bound as the second argument and
returns a random integer between those bounds.
 
===Python Twitter library functions we will use===
 
A library provides a collection of functions for you, and defines a contract for using those functions. Here are the functions in the python-twitter library that will be useful for the project:
 
<code>api.GetSearch(searchString)</code>
 
Given a string to search for, this function will return a list of tweets matching that search string.
 
<code>api.GetUserTimeline(username)</code>
 
Given a username, this function will return a list of tweets belonging to that username.
 
===Python Twitter Project Instructions===
 
Here are the [[Chicago Python Workshop/Projects/Twitter|Twitter Project Instructions]].
 
==Wordplay==
 
[[File:Crossword.png|100px]]
 
===Download the Wordplay project===
 
We've written some skeleton code for the Wordplay project already. Download this code so you're ready to start working with it tomorrow:
 
# Right click the following file, click "Save Target as..." or "Save link as...", and save it to your Desktop directory:
#* http://web.mit.edu/jesstess/www/BostonPythonWorkshop5/Wordplay/Wordplay.zip
# Windows:
## Find Wordplay.zip on your Desktop and double-click on it to "unzip" it. That will create a folder called Wordplay containing several files.
# Mac OSX
## Find Wordplay.zip on your Desktop and double-click on it. This will create a directory for Wordplay, containing the source code for the dependency.
# Linux
## Find Wordplay.tar.gz on your Desktop and double-click on it to "extract" it. That will create a folder called Wordplay containing several files.
 
===Test the Wordplay code===
 
Start a command prompt and navigate to the Desktop\Wordplay directory where the Wordplay code lives. For example, if the Wordplay project is at <code>C:\Users\jesstess\Desktop\Wordplay</code>,
 
<pre>
cd C:\Users\jesstess\Desktop\Wordplay
</pre>
 
will change you into that directory, and
 
<pre>
dir
</pre>
 
will show you the source code files in that directory. One of the files is "words1.py", which has a ".py" extension indicating that it is a Python script. Type:
 
<pre>
python words1.py
</pre>
 
at the command prompt to execute the words1.py Python script. You should see a column of English words printed to the screen. If you don't, let a staff member know.
 
===Success!===
 
You've completed setup for the Wordplay project.
 
===Wordplay goals===
Line 431 ⟶ 242:
 
===Python Wordplay Project Instructions===
Here are the [[ChicagoPhiladelphia Python Workshop/Projects/Wordplay|Wordplay Project Instructions]].
 
 
==ColorWall==
 
[[File:Colorwall_matrix.png|200px]]
 
===ColorWall goals===
 
*Learn about importing modules
*Basic introduction to classes
Anonymous user