PIC 16 Python with Applications

You can download the course information here.

Winter 2018 Tentative Course Schedule

Week 1

  • 01/08 Lecture 1: Course Overview
    – Follow instruction in GettingStarted.pdf on CCLE
    – Reading material: Python tutorial 1 and 2.1.2
  • 01/10 Lecture 2: Python Basics - Basic Data Types, commenting, list, dictionary, functions, modules
    – Reading material: Python tutorial 3.1.1, 3.1.2, 3.1.4, 5.1, 5.5
  • 01/12 Lecture 3: Python Basics - Control Flow, Functions
    – Reading material: Python tutorial 4.1 - 4.7

Week 2

  • 01/15 Martin Luther King, Jr. Holiday (No Class)
  • 01/17 Lecture 4: Python Basics - Data Structures
    – Reading material: Python tutorial 5.2 - 5.5
  • 01/19 Lecture 5: Python Basics - Functional Programming
    – Reading material: Python tutorial 6.1, 8.1 - 8.4, 5.7

** Homework 1 due Wednesday by 5pm

Week 3

  • 01/22 Lecture 6: Python Basics - Classes and Objects, Magic Methods
    – Reading material: tutorialspoint
  • 01/24 Lecture 7: Regular Expressions I
    – Reading material: tutorial
    Cheat sheet
    – To test your regular expressions: pythex
  • 01/26 Lecture 8: Regular Expressions II

** Homework 2 due Friday by 5pm

Week 4

  • 01/29 Lecture 9: Visualization I: Turtle, Matplotlib and pyplot
    Recursion
    Matplotlib tutorial
  • 01/31 Lecture 10: Visualization II: Pandas, Matplotlib and Numpy
    Pandas Tutorial
    – Pandas Basics Cheat Sheet (on CCLE)
  • 02/02 Lecture 11: Visualization III: More on plotting
    Numpy tutorial

** Homework 3 due Friday by 5pm

Week 5

** Homework 4 due Friday by 5pm

Week 6

** Homework 5 due Friday by 5pm

Week 7

  • 02/19 President’s Day Holiday (No Class)
  • 02/21 Lecture 18: NLTK
    – Read the introduction to Chapter 1 of the NLTK Book.
    – Follow 1.2, 1.3, 1.4
    – Follow Chapter 1, section 3 (all)
    – Skim Chapter 1, section 5. This will give you a good overview of the issues in natural language
    – Skim Chapter 3 for processing raw text processing.
  • 02/23 Lecture 19: Page-Rank algorithm
    – https://networkx.github.io/documentation/stable/tutorial.html#creating-a-graph
    – Read from “Creating a graph” to “Directed graphs”
    – https://en.wikipedia.org/wiki/PageRank
    – (Optional)https://www.geeksforgeeks.org/page-rank-algorithm-implementation

Week 8

** Homework 6 due Monday by 5pm

Week 9

** Homework 7 due Friday by 5pm

Week 10

** Homework 8 due Friday by 5pm

  • 03/21 Final exam