From
http://www.hetland.org/python/instant-hacking.php
Instant Hacking
// Code, pre {color: # dd440f}
Code, pre {color: # 990000}
Pre {Font-Size: 90%}
// em {color: green}
.comment {color: # 808080}
//.comment {color: blue}
->
[If you like this tutorial, please check out my book practice python.]
This is a short introduction to the art of programming, with examples written in the programming language Python. (If you already know how to program, but want a short intro to Python, you may want to check out my article Instant Python.) This Article Has Been Translated Into Italian, Polish, Japanese, Serbian
And Brazilian Portuguese, and is in the process of being translated Into Korean.
This page is not about breaking into Other People's Computer Systems etc. I'm Not Into That Sort of Thing, So Please Don't email me About it.
Note: To get the examples working properly, write the programs in a text file and then run that with the interpreter; do not try to run them directly in the interactive interpreter - not all of them will work (Please do not ask me. On detils on this. Check the documentation or send an email to help@python.org).
The environment
To program in Python, you must have an interpreter installed. It exists for most platforms (including Macintosh, Unix and Windows). More information about this can be found on the Python web site. You also should have a text editor (like emacs, Notepad or something similar).
What is programing?
PROGRAMMING A COMPUTER Means Giving It a set of instructions telling it what to do. A Computer Program in Many Ways Resembles Recipes, Like The Ones We Use for Cooking. For example [1]:
Fiesta Spam Salad
Ingredients:
MarinaDe:
1/4 Cup Lime Juice1 / 4 Cup Low-Sodium Soy Sauce
1/4 Cup Water
1 TableSpoon Vegetable Oil
3/4 TEASPOON CUMIN
1/2 Teaspoon Oregano
1/4 TEASPOON Hot Pepper Sauce
2 cloves garlic, minced
Salad:
1 (12-OUNCE) CAN spam less Sodium Luncheon Meat,
Cut INTO STRIPS
1 Onion, SLICED
1 Bell Pepper, Cut in Strips
Lettuce
12 Cherry Tomatoes, Halved
Instructions:
In jar with tight-fitting limited, combine all marinade ingredient;
Shake Well. Place Spam Strips in Plastic Bag. Pour Marinade
Over spam. Seal Bag; Marinate 30 minutes in refrigerator.
REMOVE SPAM from Bag; Reserve 2 TableSpoons Marinade. Heat
RESERVED Marinade in Large Skillet. Add spam, onion, and
Green Pepper. Cook 3 TO 4 Minutes Or Until Spam is Heated.
Line 4 Individual Salad Plates with Lettuce. Spoon Hot Salad
Garnish With Tomato Halves. Serves 4.
Of course, no computer would understand this ... And most computers would not be able to make a salad even if they did understand the recipe So what do we have to do to make this more computer-friendly Well -.? Basically two Talk In A Way That The Computer Can Understand, and (2) Talk about Things That It Can do Something with.
The first point means that we have to use a language - a programming language that we have an interpreter program for, and the second point means that we can not expect the computer to make a salad - but we can expect it to add numbers, Write things to the screen etc.
Hello ...
Tutorials to Always Begin with a Program That Prints "Hello, World!" To the screen. In Python, this is quite simple:
Print "Hello, World!"
This Is BasicalLike The Recipe Above (Although IT IS Much Shorter!). It Tells The Computer What To Do: To Print "Hello, World!". Piece of Cake. What if we would? Put it to do more stuff? Print " Hello, World! "
Print "Goodbye, World!"
NOT MUCH HARDER, WAS IT? And not really usteresting ... we want to be a to do something with the ingredients, just like - what ingredients do we have? For one think TEXT, LIKE "Hello, World!", But We Also Have Numbers. Say We Wanted The Computer To Calculate The Area of A Rectangle for US. The cele could Give It The Following Little Recipe:
# The area of a reentangle
# Ingredients:
Width = 20
HEIGHT = 30
# Instructions:
Area = width * height
Print Area
You can probably see the similarity (albeit slight) to the spam salad recipe. But how does it work? First of all, the lines beginning with # are called comments and are actually ignored by the computer. However, inserting small explanations like this can Be important in making your programs more readable to humans.
Now, the line there = 20 We Tell The CASE OF WIDTH = 20 We Tell The Computer That The Width Should Be 20 from this Point on. What does it mean That "The Width IS 20"? It means That a variable by the name "width" is created (or if it already), it is reused And Given The Value 20. So, WHEN We use the variable latter, The Computer Know ITS Value. thus,
Width * Height
Is Essentially the Same AS
20 * 30
which is calculated to be 600, which is then assigned to the variable by the name "area". The final statement of the program prints out the value of the variable "area", so what you see when you run this program is simply600
Note: In some languages you have to tell the computer which variables you need at the beginning of the program (like the ingredients of the salad) - Python is smart enough to figure this out as it goes along.
FEEDBACK
Ok. Now You Can Performed Calculation. For Instance, You Might Want to Make a Program To Calculate The Area of a Circle INSTEAD OF A Rectangle:
RADIUS = 30
Print Radius * Radius * 3.14
However, this is not significantly more interesting than the rectangle program. At least not in my opinion. It is somewhat inflexible. What if the circle we were looking at had a radius of 31? How would the computer know? It's a bit like the part of the salad recipe that says: ". Cook 3 to 4 minutes or until SPAM is heated" to know when it is cooked, we have to check We need feedback, or input How does the computer know the radius of our circle.. ? IT Too Needs Input ... What We can do is to tell it to check the radius:
RADIUS = INPUT ("What is the radius?")
Print Radius * Radius * 3.14
Now Things Are Getting Snazy ... Input Is Something Called A Function. (INPUT IS A Function That Built Into The Python Language.) Simply Writing
INPUT
Won't do much ... you have to put a pair of paranthese at the end of it. so input () Would Work - It Would IT WOULD SIMPLY WAIT for the user to enter the radius. The Version Above Is Perhaps A bit More user -friendly, though, since it prints out a question first. When we put something like the question-string "What is the radius?" between the parentheses of a function call it is called passing a parameter to the function. The thing (or THINGS ISTER (S). INSE WE PASS A Question As a parameter SO That Inpution What To Print Out Before Getting The answer from the user.but howate the answer get to the ?. radius variable The function input, when called, returns a value (like many other functions) You do not have to use this value, but in our case, we want to So, the following two statements have very different meanings.:
Foo = INPUT
Bar = INPUT ()
Foo Now Contains The Input Function Itself ("What is your age?"); this is caled a dynamic function call) While bar Contains whatver is type in by the user.
Flow
Now we can write programs that perform simple actions (arithmetic and printing) and that can receive input from the user This is useful, but we are still limited to so-called sequential execution of the commands, that is -. They have to be executed ..? in a fixed order Most of the spam salad recipe is sequential or linear like that But what if we wanted to tell the computer how to check on the cooked spam If it is heated, then it should be removed from the oven - otherwise , IT SHOULD BE COOKED for Another Minute or So. How do we express what?
What we want to do, is to control the flow of the program - Either Take Out the spam, or leave it in the oven. We can choose, and the condition is used THIS Called Conditional Execution. We can do it like this: Temperature = INPUT ("What is the temperature of the spam?")
IF Temperature> 50:
Print "The salad is protly cooked."
Else:
Print "Cook the salad some more."
The meaning of this should be obvious: If the temperature is higher than 50 (centigrades), then print out a message telling the user that it is properly cooked, otherwise, tell the user to cook the salad some more.
Note: The indentation is important in Python Blocks in conditional execution (and loops and function definitions - see below) must be indented (and indented by the same amount of whitespace; a
Let's return to ou area Calculation. Can you see What this Program Does?
# Area Calculation Program
Print "Welcome to the area Calculation Program"
Print "--------------------------------------"
# Print Out the menu:
Print "please select a shape:"
Print "1 Rectangle"
Print "2 Circle"
# Get the user's choice:
Shape = INPUT (">")
# Calculate the area:
if Shape == 1:
Height = INPUT ("please enter the height:")
Width = INPUT ("please enter the width:")
Area = height * width
Print "The Area IS", AREA
Else:
Radius = INPUT ("please enter the radius:")
Area = 3.14 * (Radius ** 2)
Print "The Area IS", AREA
New Things in this Example:
print used all by iself prints out an empty line == checks whether two things are equal, as opposed to =, which assigns the value on the right side to the variable on the left. This is an important distinction! ** is Python's power Operator - Thus the Squad Radius is Written Radius ** 2. Print Can Print Out More Than Thing. Just Separate THEM WITH COMMAS. (The Will Be Separated by Single Spaces in The Output.)
The program is quite simple:. It asks for a number, which tells it whether the user wants to calculate the area of a rectangle or a circle Then, it uses an if-statement (conditional execution) to decide which block it should use for . the area calculation These two blocks are essentially the same as those used in the previous area examples Notice how the comments make the code more readable It has been said that the first commandment of programming is: Anyway -.. "Thou shalt comment!" It's a nice habit to acquire.
EXERCISE:
Extend the program above to include area calculations on squares, where the user only has to enter the length of one side There is one thing you need to know to do this:. If you have more than two choices, you can write something like:
IF foo == 1:
# Do something ...
Elif foo == 2:
# Do something else ...
Elif foo == 3:
# Do Something Completely Different ...
Else:
# Imp All else fails ...
Here Elif Is A Mysterious Code Which Means "Else IF" :). So; if foo is one, dam, iv, ortho, ife, etc. You mightow add other options to the program Too - Like Triangles OR Arbitrary Polygons. It's up to you.
Loops
Sequential execution and conditionals are only two of the three fundamental building blocks of programming. The third is the loop. In the previous section I proposed a solution for checking if the spam was heated, but it was quite clearly inadequate. What if the spam wasn 'T Finished Time We checked Either? How Could We Know How Many Times We needed to check it? The truth is, we couldn't. and we stayn't have to. we shop becompute to ask the computer to keep . checking until it was done How do we do that You guessed it - we use a loop, or repeated execution.Python has two loop types:? while-loops and for-loops for-loops are perhaps the simplest for instance:..
For food in "spam", "Eggs", "Tomatoes":
Print "i love", food
This means: For every element in the list "spam", "eggs", "tomatoes", print that you love it The block inside the loop is executed once for every element, and each time, the current element is assigned to the. Variable Food (in this case). Another Example:
For Number In Range (1,100):
Print "Hello, World!"
Print "Just", 100 - Number, "More to Go ..."
Print "Hello, World"
Print "That Was the last one ... Phew!"
The Function Range Returns A List of Numbers in The Range Given (Including The First, Excluding The Last ... in this case, [1..99]). SO, TO Paraphrase this:
The contents of the loop is executed for each number in the range of numbers from (and including) 1 up to (and excluding) 100. (What the loop body and the following statements actually do is left as an exercise.)
But this doesn't really help us with our cooking problem; if we would qite a nice solution; but we don't know if Too musting - or if it's too much Just Want To Keep Checking It While It Is Not Hot Enough (OR, UnTil It Is Hot Enough - a Matter of Point-of-View). So, We Use While: # spam-cooking program
# Fetch the function sleep
From time import sleep
Print "Please start cooking the spam. (I'll Be Back in 3 minutes"
# Wait for 3 Minutes (That IS, 3 * 60 SECONDS) ...
Sleep (180)
Print "I'm barap :)"
# How hot is hot environment?
Hot_enough = 50
Temperature = INPUT ("How hot is the spam?")
While Temperature Print "NOT Hot Enough ... Cook It a bit more ..." Sleep (30) Temperature = INPUT ("OK. How hot is it now?") Print "It's" i're done! " New Things in this Example ... Some useful functions are stored in modules and can be imported. In this case we import the function sleep (which sleeps for a given number of seconds) from the module time which comes with Python. (It is possible to make your own modules too. ..) EXERCISE 1 Write a program from the user and adds. Write Another Program That Reads Out The Sum. Bigger Programs - Abstract If you want an overview of the contents of a book, you do not plow through all pages - you take a look at the table of contents, right It simply lists the main topics of the book Now -?. Imagine writing a cookbook. Many of the Recipes, Like "Creamy Spam and Macaroni" and "Spam Swiss Pie" May Contain Similar Things, Like Spam, in this case - yet you would''t Want To REPEAT HOW Make SPAM in Every Recipe .. So you don't actually make spam ... but bear with me for the design. You'd Put The Recipe for Spam in A Separate Chapter, And Simply Refer to It in The Other Recipes. So - instead of writing the entire recipe every time, you only had to use the name of a chapter. In computer programming this is called abstraction.Have we run into something like this already? Yup. Instead of telling the computer exactly how to get an answer From the user (OK - SO We Couldn't Really Do this ... But we couldn't really make spam either, so there ... :)) We Simply Used Input - a function. w E CAN ACTUALLY MAKE OUR OWN Functions, To Use for this Kind of Abstract. Let's say we want to find the largest integer that is less than a given positive number. For instance, given the number 2.7, this would be 2. This is often called the "floor" of the given number. (This could actually be done WITHT-IN PYTHON FUNCTION INT, But Again, Bear with me ...) How Well We do this? A Simple Solution Would Be To try All Possibilities from ZERO: Number = INPUT ("What is the number?") Floor = 0 While floor <= number: Floor = floor 1 Floor = floor-1 Print "The Floor of", Number, "IS", FLOOR Notice That The loop ends1 (or equal to) the number; we add one too much to subtract one afterwards. What if we want to use this "floor" -thing in A complex mathematical expression We would have to write the entire loop for every number that needed "floor" -ing Not very nice ... You have probably guessed what we will do instead:?. Put it all in a function of our own, called "floor": Def floor (Number): Result = 0 While Result <= number: Result = Result 1 Result = Result-1 Return RESULT New Things in this Example ... Functions are defined with the keyword def, followed by their name and the expected parameters in parentheses. If the function is to return a value, this is done with the keyword return (which also automatically ends the function. Now That We Have Defined It, WE CAN Use IT Like this: X = 2.7 Y = floor (2.7) After this, Y Should Have The Value 2. It is also Possible to make functions with more one parameter: DEF SUM (X, Y): Return X Y EXERCISE 2 Write a Function That Implements Euclid's Method for Finding A Common Factor of Two Numbers. It works like this: You Have Two Numbers, A and B, WHERE A is Larger Than B You Repeat The Following UnTil B Becomes ZERO: A is Changd to the Value of B B Is Changed To The Remainder WHEN A (Before The Change) You Then Return The Last Value of A Hints: Use a and b as parameters to the function Simply assume that a is greater than b The remainder when x is divided by z is calculated by the expression x% z Two variables can be assigned to simultaneously like this: x, y = y, y 1. Here x is given the value of y ("IS, THE VALUE Y HAD BEFORE THE Assignment) and y is increment by OneMore About Functions How Did THE EXERCISE Go? WAS IT DIFFICULT? STILL A BIT CONFUSED ABOUT FUNCTIONS? Don't worry - i haven't left the Topic Quite Yet. The sort of abstraction we have used when building functions is often called procedural abstraction, and many languages use the word procedure along with the word function. Actually, the two concepts are different, but both are called functions in Python (since they are defined and Used in The Same Way, More Or Less.) What is the difference (in other languages) between functions and procedures Well -? As you saw in the previous section, functions can return a value The difference lies in that procedures do not return such a value In many ways, this way of.. Dividing functions Into Two Types - Those Who Do And Those Who Don't return VALUES - Can Be Quite Useful. A function that does not return a value (a "procedure") is used as a "sub-program" or subroutine. We call the function, and the program does some stuff, like making whipped cream or whatever. We can use this ........................ The Usefulness of Such A Function (or Procedure) Lies in ITS Side Effects - IT Changes ITS Environment (by Mixing The Suger and Cream and Whipping It, for Instance ...) Let's Look At An Example: Def Hello (WHO): Print "Hello,", WHOHELLO ("World") #Prints out "Hello, World" Printing out stuff is considered a side effect, and since that is all this function does, it is quite typical for a so-called procedure. But ... It does not really change its environment does it? How could it do that? Let's TRY: # The * WRONG * WAY OF DOING IT AGE = 0 DEF Setage (a): AGE = a Setage (100) Print agn #Prints "0" What's Wrong Here? The Problem Is That The Function Setage Creates It Own Local Variable, Also Named Age Which is Only Seen Inside Setage. How Can We Avoid That? We can Use Something Called Global Variables. Note: Global Variables Are Not Used Much in Python. They Easily Lead to Bad Structure, or what is called spaghetti code. I use the the the theore. - please Avoid Themy You CAN. By telling the interpreter that a variable is global (done with a statement like global age) we effectively tell it to use the variable outside the function instead of creating a new local one. (So, it is global as opposed to local.) The Program can kiln il tris: # The Correct, But not-so-good way of doing it AGE = 0 DEF Setage (a): Global Age AGE = a Setage (100) Print agn #Prints "100" When you learn about objects (below), you'll see that a more appropriate way of doing this would be to use an object with an age property and a setAge method. In the section on data structures, you will also see some better examples Of functions this change their environment. Well - what about real functions, then What is a function, really Mathematical functions are like a kind of "machine" that gets some input and calculates a result It will return the same result every time, when presented with the same input??. For Instance: Def Square (x): Return x * x This is The Same as The Mathematical Function F (x) = x2. It behaves Like a Nice Function, IN That Only Relies on ITS INPUT, AND IT DoES NOT CHANGE ITS ENVIRONMENT IN ANY WAY. So - I have outlined two ways of making functions: One type is more like a procedure, and does not return a result; the other is more like a mathematical function and does not do anything but returning a result (almost) Of. course, it is possible to do something in between the two extremes, although when a function changes things, it should be clear that it does. You could signal this through its name, for instance by using only a noun for "pure" functions like Square and an imperative for procedure-like functions like setage. More Ingredients - Data Structures Well - You Know A Lot Already: How to Get Input and Give Output, How To Structure Complicated Algorithms (Program) and to Perform Arithmetic; And Yet The Best Is Still To Come. What INGREDIENTS HAVE WE BEEN USING IN OUR Program Up Until now Numbers and strings. Right? Kinda Boring ... no let's introduce a couple of other ingredients to make things a bit more exciting. Data structures are ingredients that structure data (Surprise, surprise ...) A single number does not really have much structure, does it But let's say we want more numbers put together to a single ingredient -.? That would have some structure. For Instance, WE Might Want a list of number: [3, 6, 78, 93] I Mentioned Lists in The Section On Loops, But Didn't Really Say Much About Them. Well - this is how you make it. Just List the elements, Separated by Commas and enclosed in Brackets. Let us Jump INTO An Example That Calculates Primes (Numbers Divisible Only by Themselves OR 1): # Calculate all the primes belloW 1000 # (NOT The Best Way to Do It, But ...) Result = [1] Candidates = Range (3,1000) Base = 2 Product = BASE While Candidates: While Producuct <1000: IF Product in Candidates: Candidates.Remove (Product) Product = Product Base Result.Append (Base) Base = Candidates [0] Product = BASE Del Candidates [0] Result.Append (Base) Print Result New Things in this Example ... (IT IT IS NOT) A LIST CAN BE Used as a List Can Be Used As a Logic Variable. If IT IS NOT EMPTY, THEN IT IS NOT. is true -.. if it is empty, then it is false Thus, while candidates means "while the list named candidates is not empty" or simply "while there are still candidates" You can write if someElement in someList to check if an element is in a list. you can write someList.remove (someElement) to remove someElement from someList. you can append an element to a list by using someList.append (something). Actually, you can use too (as in someList = someList [Something]) But it is not as efficient. You can get at an element of a list by giving its position as a number (where the first element, strangely, is element 0) in brackets after the name of the list. thusdomelist [3] Is The Fourth Element of The List Somelist.) You can delete variables by using the keyword del. it Can Also Be Used (As Here) To Delete Elements from A List. Thus del Somelist [0] deletes the first element ofdom. if the list was [1,2,3] before the deletion, IT Would Be [2, 3 ] afterwards.before going on to explaining the mysteries of indexing list elements, i will give a brief explanation of the example. This is a version of the ancient algorithm called "The Sieve of Erastothenes" (or something close to that). It considers a set (or in this case, a list) of candidate numbers, and then systematically removes the numbers known not to be PRIMES. How do we know? Because They areproducts of two other numbers. We Start with a list of Candidates Containing Numbers [2..999] - We know That 1 IS A Prime (Actually, IT May Or May Not Be, Depending On Who You ASK), And We Wanted All Primes Below 1000. (Actually , Our List of Candidates IS [3..999], But 2 IS OUR First Base. We Also Have a list Called Result Which At All Times Contains The Updated Results So Far. To Begin with this list contains only the number 1. We also have a variable called base. For each iteration ( "round") of the algorithm, we remove all numbers that are some multible of this base number (which is always the smallest of the candidates) . After each iteration, we know that the smallest number left is a prime (since all the numbers that were products of the smaller ones are removed -? get it) Therefore, we add it to the result, set the new base to this. Number, And Remove It From The Candidate List (So We Won't Process It Again.) When the Result List Will Contain All The Result List Will Contain All There Primes. Clever, Huh? Things to Think About: What is special with the first ity? Here the base is 2, yet what too than? why doesn't That happen to the other base ban? can WE BE SURE THAT PRODUCT IS ALWAYS in The Candidate List WHEN WANT To Remove It? why? Now - what next Ah, yes ... Indexing And slicing These are the ways to get at the individual elements of Python lists You have already seen ordinary indexing in action It is pretty straightforward Actually, I have told you?..... All you need to know about it, except for one: Negative indices count from the end of the list. so, somelist [-1] is the last element of some oselist, somelist [-2] is the element before what, and so ON. Slicing, HoWever, Should Be New To You. It is Similar To Indexing, Except with Slicing You Can Target An entire slice of the list, and not just a single element. How is it done? Like this: food = ["spam" , "Spam", "Eggs", "Sausages", "spam"] Print Food [2: 4] #Prints "['Eggs', 'Sausages']" More Abstract - Objects and Object-Oriented Programming Now There's a buzz-Word if Ever there is: "Object-Oriented Programming." As the section title suggests, object-oriented programming is just another way of abstracting away details. Procedures abstract simple statements into more complex operations by giving them a name. In OOP, we do not just treat the operations this way, but objects. (Now, that must have been a big surprise, huh?) For instance, if we were to make a spam-cooking-program, instead of writing lots of procedures that dealt with the temperature, the time, the ingredients etc., we could lump it toghether into a spam-object. Or, perhaps we could have an oven-object and a clock-object too ... Now, things like temperature would just be attributes of the spam-object, while the time could be read From the clock-object. and to make our program do something, we could Teach Our Object Some Methods; for instance, the Oven might know how to cook the spam etc. So - how do we do this in Python Well we can not just make an object directly Instead of just making an oven, we make a recipe describing how ovens are This recipe then describes a class of objects that we call ovens?... A Very Simple Oven Class Might BE: Class Oven: Def InsertSpam (Self, SPAM): Self.spam = SPAM DEF getSPam (Self): Return Self.spam Now, Does this Look Weird, or what? New Things in this Example ... Classes of objects are defined with the keyword class. Class names usually start with capital letters, whereas functions and variables (as well as methods and attributes) start with lowercase letters. Methods (ie the functions or operations that the objects know how to do) are defined in the normal way, but inside the class block. All object methods should have a first parameter called self (or something similar ...) The reason will (hopefully) become clear in a moment. Attributes and methods of an object are Accessed Like this: myspam.temperature = 2, or dilbert.be_nice (). I Would Guess That Some Things Are Still A Bit Unclear About The Example. For Instance, What Is this Self Thing? And, Now That WE Have An Object Recipe (I.E. Class), How do we actually make an object? Let's Tackle The Last Point First. An Object IS CREATED BY CALLING THE CLASSNAME AS OF IT WERE A FUNCTION: Myoven = Oven () Myoven Now Contains An Oven Object, Usually Called An Instance of The Class Oven. Let's Assume That We Have Made A Class Spam as Well; THEN We Could do Something Like: myspam = spam () Myoven.insertspam (MySPAM) myOven.spam would now contain mySpam. How come? Because, when we call one of the methods of an object, the first parameter, usually called self, always contains the object itself. (Clever, huh?) Thus, the line self. Spam = spam sets the attribute spam of the capital Oven Object to the value of the parameter spam. Note THESE The.. Answer to EXERCISE 2 Here Is a Very Concise Version of the Algorithm: Def Euclid (A, B): While B: A, B = B, A% B Return areferences [1] Recipe for Fiesta Spam Salad Taken From The HorMel Foods Digital Recipe Book Copyright © MAGNUS LIE HETLAND