Python 2008-11-14 Bryce Boe.

Slides:



Advertisements
Similar presentations
Introduction to Python LinuxWorld - New York City - January 2002 Guido van Rossum Director of PythonLabs at Zope Corporation
Advertisements

10/10/1999© 1999 CNRI, Guido van Rossum 1 Python Workshop Guido van Rossum CNRI (Corporation for National Research Initiatives, Reston, Virginia,
Introduction to Python Week 15. Try It Out! Download Python from Any version will do for this class – By and large they are all mutually.
A Crash Course Python. Python? Isn’t that a snake? Yes, but it is also a...
I210 review Fall 2011, IUB. Python is High-level programming –High-level versus machine language Interpreted Language –Interpreted versus compiled 2.
Introduction to Python Fred L. Drake, Jr.
What is a scripting language? What is Python?
Python Tidbits Python created by that guy ---> Python is named after Monty Python’s Flying Circus 1991 – Python Released 2008 – Python 2.6 / 3.0rc2.
Introduction to Python. Outline Python IS ……. History Installation Data Structures Flow of Control Functions Modules References.
C. Varela, Adapted with permission from Guido van Rossum1 Python Intro, Concurrency Carlos Varela RPI Adapted with permission from: Guido van Rossum
Introduction to Python (for C++ programmers). Background Information History – created in December 1989 by Guido van Rossum Interpreted Dynamically-typed.
Introduction to Python Lecture 1. CS 484 – Artificial Intelligence2 Big Picture Language Features Python is interpreted Not compiled Object-oriented language.
Introduction to Python Guido van Rossum Director of PythonLabs at Zope Corporation
Introduction to Scripting Languages: Python Some slides are based upon Python Documentation - Extended.
Introduction to Python LinuxWorld - New York City - January 2002 Guido van Rossum Director of PythonLabs at Zope Corporation (Now with: Google Inc.)
1 Programming in Python Language Overview. 2 Who is using it? Google (various projects) NASA (several projects) NYSE (one of only three languages "on.
1 Python CIS*2450 Advanced Programming Concepts Material for this lecture was developed by Dr. D. Calvert.
CPTR 124 Review for Test 1. Development Tools Editor Similar to a word processor Allows programmer to compose/save/edit source code Compiler/interpreter.
H3D API Training  Part 3.1: Python – Quick overview.
Documentation / References Python Full Documentation – Python Quick Reference –
Built-in Data Structures in Python An Introduction.
Getting Started with Python: Constructs and Pitfalls Sean Deitz Advanced Programming Seminar September 13, 2013.
Introducing Python CS 4320, SPRING Resources We will be following the Python tutorialPython tutorial These notes will cover the following sections.
C463 / B551 Artificial Intelligence Dana Vrajitoru Python.
Introduction to Python LinuxWorld - New York City - January 2002 Guido van Rossum Director of PythonLabs at Zope Corporation (Now with: Google Inc.)
An Introduction. What is Python? Interpreted language Created by Guido Van Rossum – early 90s Named after Monty Python
Python I Some material adapted from Upenn cmpe391 slides and other sources.
Python Primer 1: Types and Operators © 2013 Goodrich, Tamassia, Goldwasser1Python Primer.
CS105 Computer Programming PYTHON (based on CS 11 Python track: lecture 1, CALTECH)
Jim Havrilla. Invoking Python Just type “python –m script.py [arg]” or “python –c command [arg]” To exit, quit() or Control-D is used To just use the.
By Austin Laudenslager AN INTRODUCTION TO PYTHON.
Python Let’s get started!.
A Tutorial on the Python Programming Language. Overview Running Python and Output Data Types Input and File I/O Control Flow Functions.
Introduction to Programming Oliver Hawkins. BACKGROUND TO PROGRAMMING LANGUAGES Introduction to Programming.
1 Python K. Naik, M. Raju and S. Bhatkar December 3, 2002 CMSC 631.
Introduction to Scripting Languages: Python Some slides are based upon Python Documentation - Extended.
PYTHON PROGRAMMING. WHAT IS PYTHON?  Python is a high-level language.  Interpreted  Object oriented (use of classes and objects)  Standard library.
11/04/2009 © 1999 CNRI, Guido van Rossum 1 Python Crash Course Original Document : Python Workshop
Scientific Programming in Python -- Cheat Sheet
Key Words / Reserved Words
CS1022 Computer Programming & Principles
CS170 – Week 1 Lecture 3: Foundation Ismail abumuhfouz.
Python Let’s get started!.
Introduction to Programming with Python
CS-104 Final Exam Review Victor Norman.
Lecture 10 Data Collections
Statement atoms The 'atomic' components of a statement are: delimiters (indents, semicolons, etc.); keywords (built into the language); identifiers (names.
Python is a general-purpose interpreted, interactive, object-oriented, and high-level programming language. It was created by Guido van Rossum during.
Introduction to Python
Introduction to Python
Introduction to Python
Introduction to Python
Introduction to Python
CS190/295 Programming in Python for Life Sciences: Lecture 6
I210 review.
Python I Some material adapted from Upenn cmpe391 slides and other sources.
Overview of OOP Terminology
Python Tutorial for C Programmer Boontee Kruatrachue Kritawan Siriboon
Python I Some material adapted from Upenn cmpe391 slides and other sources.
Python Primer 1: Types and Operators
Introduction to Python LinuxWorld - New York City - January 2002
(more) Python.
Programming in Python Language Overview
By Ryan Christen Errors and Exceptions.
Lecture 7: Python’s Built-in Types and Basic Statements
Python Review
Enclosing delimiters Python uses three style of special enclosing delimiters. These are what the Python documentation calls them: {} braces # Sometimes.
Learning Python 5th Edition
PYTHON - VARIABLES AND OPERATORS
Presentation transcript:

Python 2008-11-14 Bryce Boe

About Me Adam’s housemate of 3 years UCSB graduate and first year Ph.D. student Nearly exclusive python user Wrote a web crawling framework in python CRAWL-E - http://code.google.com/p/crawl-e My Python claim to fame: Nearly bumped into Guido van Rossum at Google More info: http://cs.ucsb.edu/~bboe 2008/11/14

Python Tidbits Python created by that guy ---> Python is named after Monty Python’s Flying Circus 1991 – Python 0.9.0 Released 2008 – Python 2.6 / 3.0rc2 *6th most popular language Following: Java, C, C++, Visual Basic, PHP Guido van Rossum *http://www.tiobe.com/tiobe_index/index.htm 2008/11/14

Why Python High Level Language (HLL) Rapid development Very Readable Code Up to 10x shorter code than Java/C/C++ Object Oriented Dynamically Typed Many standard packages and modules Numerous third-party packages Twisted, NumPy, SciPy, PIL, M2Crypto 2008/11/14

Standard Python Modules String Modules string re StringIO / cStringIO Data Compression gzip, bz2, zipfile, tarfile Data Structures heapq, array, datetime, calendar Networking socket urllib, urllib2, httplib, ftplib, poplib, imaplib, nntplib, smtplib, telnetlib smtpd, SocketServer, BaseHTTPServer Others crypt hashlib pickle / cPickle threading Full list: http://docs.python.org/library/ 2008/11/14

Get on with it! 2008/11/14

Key Words and exec or as finally pass assert for print break from raise class global return continue if try def import while del in with elif is yield else lambda except not 2008/11/14

Types Immutable Mutable Numbers Strings Tuples Lists Dictionaries Sets Most user defined objects 2008/11/14

Numbers The usual suspects C-style shifting & masking 12, 3.14, 0xFF, 0377, (-1+2)*3/4**5 abs(x), 0<x<=5 C-style shifting & masking 1 << 16, x & 0xff, x | 1, ~x, x^y Integer division truncates 1/2 -> 0 # 1./2 -> 0.5, float(1)/2 -> 0.5 Long (arbitrary precision), complex 2**100 -> 1267650600228229401496703205376L 1j**2 -> (-1+0j) (c) Guido van Rossum 2008/11/14

Strings "hello"+"world" "helloworld" # concatenation "hello"*3 "hellohellohello" # repetition "hello"[0] "h" # indexing "hello"[-1] "o" # (from end) "hello"[1:4] "ell" # slicing "hello"[::2] "hlo" # more slicing len("hello") 5 # size "hello" < "jello” True # comparison "e" in "hello" True # search "escapes: \n etc, \033 etc, \if etc" 'single quotes' """triple quotes""" r"raw strings" (c) Guido van Rossum 2008/11/14

More Strings Formatted Strings Splitting Joining >>> "Pi: %.5f - Pi/2: %.5f" % (math.pi, math.pi/2) 'Pi: 3.14159 - Pi/2: 1.57080' Splitting >>> "The quick brown fox jumps".split() ['The', 'quick', 'brown', 'fox', 'jumps'] Joining >>> '?'.join(['The', 'quick', 'brown', 'fox', 'jumps']) 'The?quick?brown?fox?jumps' 2008/11/14

Lists Flexible arrays, not linked lists Same operators as for strings a = [99, "bottles of beer", ["on", "the", "wall"]] Same operators as for strings a+b, a*3, a[0], a[-1], a[1:], len(a) Item and slice assignment a[0] = 98 a[1:2] = ["bottles", "of", "beer"] -> [98, "bottles", "of", "beer", ["on", "the", "wall"]] del a[-1] # -> [98, "bottles", "of", "beer"] (c) Guido van Rossum 2008/11/14

More List Operations >>> a = range(5) # [0,1,2,3,4] >>> a.append(5) # [0,1,2,3,4,5] >>> a.pop() # [0,1,2,3,4] 5 >>> a.insert(0, 42) # [42,0,1,2,3,4] >>> a.pop(0) # [0,1,2,3,4] 5.5 >>> a.reverse() # [4,3,2,1,0] >>> a.sort() # [0,1,2,3,4] (c) Guido van Rossum 2008/11/14

Dictionaries Hash tables, "associative arrays" Lookup: d = {"duck": "eend", "water": "water"} Lookup: d["duck"] -> "eend" d["back"] # raises KeyError exception Insert, delete, overwrite: d["back"] = "rug" # {"duck": "eend", "water": "water", "back": "rug"} del d["water"] # {"duck": "eend", "back": "rug"} d["duck"] = "duik" # {"duck": "duik", "back": "rug"} (c) Guido van Rossum 2008/11/14

More Dictionary Operations Keys, values, items: d.keys() -> ["duck", "back"] d.values() -> ["duik", "rug"] d.items() -> [("duck","duik"), ("back","rug")] Presence check: d.has_key("duck") -> True d.has_key("spam") -> False "duck" in d -> True; "spam" in d -> False Values of any type; keys almost any {"name":"Bryce", "age":22, ("hello","world"):1, 42:"yes", "flag": ["red","white","blue"]} (c) Guido van Rossum 2008/11/14

Dictionary Details Keys must be immutable: numbers, strings, tuples of immutables these cannot be changed after creation reason is hashing (fast lookup technique) not lists or other dictionaries these types of objects can be changed "in place" no restrictions on values Keys will be listed in arbitrary order again, because of hashing (c) Guido van Rossum 2008/11/14

Tuples key = (lastname, firstname) point = x, y, z # parentheses optional x, y, z = point # unpack lastname = key[0] singleton = (1,) # trailing comma!!! empty = () # parentheses! tuples vs. lists; tuples immutable (c) Guido van Rossum 2008/11/14

Variables No need to declare Need to assign (initialize) use of uninitialized variable raises exception Dynamically typed if friendly: greeting = "hello world" else: greeting = 12**2 print greeting Everything is a "variable": Even functions, classes, modules (c) Guido van Rossum 2008/11/14

Reference Semantics Assignment manipulates references x = y does not make a copy of y x = y makes x reference the object y references Very useful; but beware! Example: >>> a = [1, 2, 3] >>> b = a >>> a.append(4) >>> print b [1, 2, 3, 4] (c) Guido van Rossum 2008/11/14

Control Structure if condition: statements [elif condition: [else: statements] while condition: statements [else: statements] for var in sequence: break continue (c) Guido van Rossum 2008/11/14

Grouping Indentation C Python int i; for i in range(20): Bingo! --- 3 6 9 12 15 18 int i; for (i = 0; i < 20; i++) { if (i%3 == 0) { printf("%d\n", i); if (i%5 == 0) { printf("Bingo!\n" ); } printf("---\n"); for i in range(20): if i%3 == 0: print i if i%5 == 0: print "Bingo!" print "---" (c) Guido van Rossum 2008/11/14

Functions, Procedures def name(arg1, arg2=some_val, ..., *v, **kw): """documentation""" # optional doc string statements return # from procedure # implied None return expression # from function (c) Guido van Rossum 2008/11/14

Example Function def gcd(a, b): "greatest common divisor" while a != 0: a, b = b%a, a # parallel assignment return b >>> gcd.__doc__ 'greatest common divisor' >>> gcd(12, 20) 4 (c) Guido van Rossum 2008/11/14

Classes class name(object): "documentation" statements -or- class name(base1, base2, ...): ... Most, statements are method definitions: def name(self, arg1, arg2, ...): May also be class variable assignments (c) Guido van Rossum 2008/11/14

Example Class class Stack: "A well-known data structure…" def __init__(self): # constructor self.items = [] def push(self, x): self.items.append(x) # the sky is the limit def pop(self): x = self.items[-1] # what happens if it’s empty? del self.items[-1] return x def is_empty(self): return len(self.items) == 0 # Boolean result (c) Guido van Rossum 2008/11/14

Using Classes To create an instance, simply call the class object: x = Stack() # no 'new' operator! To use methods of the instance, call using dot notation: x.is_empty() # -> True x.push(1) # [1] x.is_empty() # -> False x.push("hello") # [1, "hello"] x.pop() # -> "hello" # [1] To inspect instance variables, use dot notation: x.items # -> [1] (c) Guido van Rossum 2008/11/14

Subclassing class FancyStack(Stack): "stack with added ability to inspect inferior stack items" def peek(self, n): """peek(0) returns top; peek(-1) returns item below that; etc.""" size = len(self.items) assert 0 <= n < size # test precondition return self.items[size-1-n] (c) Guido van Rossum 2008/11/14

Subclassing (2) class LimitedStack(FancyStack): "fancy stack with limit on stack size" def __init__(self, limit): self.limit = limit FancyStack.__init__(self) # base class constructor def push(self, x): assert len(self.items) < self.limit FancyStack.push(self, x) # "super" method call (c) Guido van Rossum 2008/11/14

Modules Collection of stuff in foo.py file Importing modules: functions, classes, variables Importing modules: import re; print re.match("[a-z]+", s) from re import match; print match("[a-z]+", s) Import with rename: import re as regex from re import match as m (c) Guido van Rossum 2008/11/14

Packages Collection of modules in directory Must have __init__.py file May contain subpackages Import syntax: from P.Q.M import foo; print foo() from P.Q import M; print M.foo() import P.Q.M; print P.Q.M.foo() import P.Q.M as M; print M.foo() # new (c) Guido van Rossum 2008/11/14

Catching Exceptions def foo(x): return 1/x def bar(x): try: print foo(x) except ZeroDivisionError, message: print "Can’t divide by zero:", message else: # Only executed if no exceptions are caught pass bar(0) (c) Guido van Rossum 2008/11/14

Try-finally: Cleanup f = open(file) try: process_file(f) finally: f.close() # always executed print "OK" # executed on success only (c) Guido van Rossum 2008/11/14

File Objects f = open(filename[, mode[, buffersize]) methods: mode can be "r", "w", "a" (like C stdio); default "r" append "b" for text translation mode append "+" for read/write open buffersize: 0=unbuffered; 1=line-buffered; buffered methods: read([nbytes]), readline(), readlines() write(string), writelines(list) seek(pos[, how]), tell() flush(), close() fileno() (c) Guido van Rossum 2008/11/14

A Program in C Overflowed 1. #include <stdio.h> 2. #include <stdlib.h> 3. int main() { 4. srand(time()); 5. int i, j, random_odd[10]; 6. // Generate random odd integers 7. for (i = j = 0; i < 10; i++) { 8. random_odd[j] = rand() % 10000; 9. if (random_odd[j] % 2) 10. j += 1; 11. } 12. for (i = 0; i < j; i++) 13. printf("%d\n", random_odd[i]); 14. // Calculate the product 15. unsigned long product; 16. for (i = 0; i < j; i++) 17. product *= random_odd[i]; 18. printf(”\n%lu\n", product); 19. } lappy2:~ bryce$ ./a.out 4989 3881 9457 3049 843 6709 7813 7281 2062446592 Overflowed 2008/11/14

And in Python Automatically Extended 1. #!/usr/bin/env python 2. import random 3. 4. # Generate random odd integers 5. # Using a list comprehension 6. random_odd = [x for x in random.sample(range(10000), 10) if x % 2] 7. for num in random_odd: 8. print num 9. 10. # Calculate the product 11. print '\n', reduce(lambda x, y: x*y, random_odd) lappy2:~ bryce$ ./blah.py 1303 1987 4959 8389 107707658703111 Automatically Extended 2008/11/14

References Python Tutorial: Python Documentation: Many slides from: http://docs.python.org/tutorial/ Python Documentation: http://docs.python.org/library/index.html Many slides from: http://www.python.org/doc/essays/ppt/lwnyc200 2/intro22.ppt 2008/11/14

Questions? Source: http://www.xkcd.com 2008/11/14