VISUAL QUICKSTART GUIDE PYTHON Second Edition Toby Donaldson Peachpit Press Visual QuickStart Guide Python, Second Edition Toby Donaldson Peachpit Press 1249 Eighth Street Berkeley, CA 94710 510/524-2178 510/524-2221 (fax) Find us on the Web at www.peachpit.com. To report errors, please send a note to [email protected]. Peachpit Press is a division of Pearson Education. Copyright © 2009 by Toby Donaldson Editors: Cliff ord Colby and Elissa Rabellino Production Editor: Myrna Vladic Compositor: Debbie Roberti Indexer: Julie Bess Cover Design: Peachpit Press Notice of Rights All rights reserved. No part of this book may be reproduced or transmitted in any form by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of the publisher. For information on getting permission for reprints and excerpts, contact [email protected]. Notice of Liability Th e information in this book is distributed on an “As Is” basis without warranty. While every precaution has been taken in the preparation of the book, neither the author nor Peachpit shall have any liability to any person or entity with respect to any loss or damage caused or alleged to be caused directly or indirectly by the instructions contained in this book or by the computer software and hardware products described in it. Trademarks Visual QuickStart Guide is a registered trademark of Peachpit Press, a division of Pearson Education. Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and Peachpit was aware of a trademark claim, the designations appear as requested by the owner of the trademark. All other product names and services identifi ed throughout this book are used in editorial fashion only and for the benefi t of such companies with no intention of infringement of the trademark. No such use, or the use of any trade name, is intended to convey endorsement or other affi liation with this book. ISBN 13: 978-0-321-58544-8 ISBN 10: 0-321-58544-5 9 8 7 6 5 4 3 2 1 Printed and bound in the United States of America Acknowledgments Th anks to Cliff ord Colby and Elissa Rabellino, for their expertise and patience in bringing this book to life; to the many students at SFU who continue to teach me how best to learn Python; to John Edgar and the other com- puter science teachers at SFU with whom I’ve had the pleasure to work; to Bonnie, for her wise advice to avoid using the word blithering more than once in these acknowl- edgments; and to Th omas, for resisting the at-times clearly overwhelming urge to eat, tear, or suck on early drafts of this book. And a special thank-you to Guido van Rossum and the rest of the Python commu- nity, for creating a programming language that is so much fun to use. Table of Contents Chapter 1: Introduction to Programming 1 Th e Python Language . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 What Is Python Useful For? . . . . . . . . . . . . . . . . . . . . . . 3 How Programmers Work . . . . . . . . . . . . . . . . . . . . . . . . . 4 Installing Python . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 Chapter 2: Arithmetic, Strings, and Variables 7 Th e Interactive Command Shell . . . . . . . . . . . . . . . . . . 8 s Integer Arithmetic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 t n Floating Point Arithmetic . . . . . . . . . . . . . . . . . . . . . . . 11 e t Other Math Functions . . . . . . . . . . . . . . . . . . . . . . . . . . 14 n o Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 C String Concatenation . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 f o Getting Help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18 e Converting Between Types . . . . . . . . . . . . . . . . . . . . . . 20 l b Variables and Values . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 a T Assignment Statements . . . . . . . . . . . . . . . . . . . . . . . . . 24 How Variables Refer to Values . . . . . . . . . . . . . . . . . . . 26 Multiple Assignment . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Chapter 3: Writing Programs 29 Using IDLE’s Editor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Compiling Source Code . . . . . . . . . . . . . . . . . . . . . . . . . 33 Reading Strings from the Keyboard . . . . . . . . . . . . . . 34 Printing Strings on the Screen . . . . . . . . . . . . . . . . . . . 37 Source Code Comments . . . . . . . . . . . . . . . . . . . . . . . . 39 Structuring a Program . . . . . . . . . . . . . . . . . . . . . . . . . . 40 Chapter 4: Flow of Control 41 Boolean Logic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 If-Statements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Code Blocks and Indentation . . . . . . . . . . . . . . . . . . . 49 Loops . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52 Comparing For-Loops and While-Loops . . . . . . . . . 57 Breaking Out of Loops and Blocks . . . . . . . . . . . . . . . 61 Loops Within Loops . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 iv Table of Contents Chapter 5: Functions 63 Calling Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Defi ning Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 Variable Scope . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69 Using a main Function . . . . . . . . . . . . . . . . . . . . . . . . . . 72 Function Parameters . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 Modules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77 Chapter 6: Strings 81 String Indexing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82 Characters . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85 Slicing Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87 Standard String Functions . . . . . . . . . . . . . . . . . . . . . . 90 Regular Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96 Chapter 7: Data Structures 99 Th e type Command . . . . . . . . . . . . . . . . . . . . . . . . . . . .100 Ta Sequences . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .101 b l Tuples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .102 e o Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .105 f List Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .107 C o Sorting Lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .110 n t List Comprehensions . . . . . . . . . . . . . . . . . . . . . . . . . .112 e n Dictionaries . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .115 t s Sets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .119 Chapter 8: Input and Output 121 Formatting Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . .122 String Formatting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .124 Reading and Writing Files . . . . . . . . . . . . . . . . . . . . . .126 Examining Files and Folders . . . . . . . . . . . . . . . . . . .129 Processing Text Files . . . . . . . . . . . . . . . . . . . . . . . . . . .132 Processing Binary Files . . . . . . . . . . . . . . . . . . . . . . . .136 Reading Web Pages . . . . . . . . . . . . . . . . . . . . . . . . . . . .139 Chapter 9: Exception Handling 141 Exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .142 Catching Exceptions . . . . . . . . . . . . . . . . . . . . . . . . . . .144 Clean-Up Actions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .147 v Table of Contents Chapter 10: Object-Oriented Programming 149 Writing a Class . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .150 Displaying Objects . . . . . . . . . . . . . . . . . . . . . . . . . . . . .152 Flexible Initialization . . . . . . . . . . . . . . . . . . . . . . . . . .155 Setters and Getters . . . . . . . . . . . . . . . . . . . . . . . . . . . .157 Inheritance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .162 Polymorphism . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .165 Learning More . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .169 Appendix A: Popular Python Packages 171 Appendix B: Comparing Python 2 and Python 3 175 What’s New in Python 3 . . . . . . . . . . . . . . . . . . . . . . . .176 Converting Python 2 to Python 3 . . . . . . . . . . . . . . .177 Index 179 s t n e t n o C f o e l b a T vi 1 Introduction to Programming Before we dive into the details of Python programming, it helps to learn a bit about what Python is and what kinds of programs it is used for. We will also outline exactly what it is that programmers do. Finally, we’ll learn how to install Python and run the IDLE edi- I n tor that comes with it. t r o If you are new to programming, this short d u introduction should help you get your foot- c t ing in preparation for learning the Python i o programming language. n t If you already have a grasp of the basic con- o P cepts, feel free to jump ahead to the sections r on how to install Python and run the editor. o g r a m m i n g 1 Chapter 1 The Python Language So what is Python? Briefl y, it is a computer programming language and a corresponding set of software tools and libraries. It was origi- nally developed in the early 1990s by Guido van Rossum, and it is now actively main- tained by dozens of programmers around the world (including van Rossum). Python was designed to be easy to read and learn. Compared with programs written in most other programming languages, Python programs look neat and clean: Python has few unnecessary symbols, and it uses straightforward English names instead of the cryptic syntax common in other languages (Ruby and Perl, I’m looking at you!). Python is a very productive language: Once you're profi cient with Python, you can get more done with it in less time than you can in e g most other programming languages. Python a supports—but doesn't force you to use— u g object-oriented programming (OOP). n a L Python comes with a wide range of ready- n made libraries that can be (freely!) used o h in your own programs; as some Python t y programmers like to say, Python comes with P e “batteries included.” h T One of the most important features of Python is its maintainability: Since Python programs are relatively easy to read and modify, they are easy for programmers to keep up to date. Program maintenance can easily account for 50 percent or more of the work a programmer does, and so Python’s support for maintenance is a big win in the eyes of many professionals. Finally, a word about the name. According to Python’s originator, Guido van Rossum, Python was named after the Monty Python comedy troupe. Despite this mirthful origin, Python now uses a pair of iconic blue and yellow snakes—presumably pythons—as its standard symbol. 2 Introduction to Programming What Is Python Useful For? While Python is a general-purpose language that can be used to write any kind of pro- gram, it is especially popular for the following applications: ◆ Scripts. Th ese short programs automate common administrative tasks, such as add- ing new users to a system, uploading fi les to a Web site, downloading Web pages with- out using a browser, and so on. Due to its simplicity, Python is also a popular choice as a scripting language for many products, such as the video game Civilization 4. ◆ Web-site development. A number of Python projects—such as Django (www.djangoproject.com), Turbo Gears (www.turbogears.org), and Zope (www.zope.org)—are popular among W many Web-site developers as tools for h quickly creating dynamic Web sites. a t For instance, the popular news site I s www.reddit.com was written using Python. P y ◆ Text processing. Python has excellent t h support for handling strings and text fi les, o n including regular expressions and Unicode. U s ◆ Scientifi c computing. Many superb e f scientifi c Python libraries are available u l on the Web, providing functions for F statistics, mathematics, and graphing. o r ? ◆ Education. Th anks to its relative simplic- ity and utility, Python is becoming more and more popular as a fi rst programming language in schools. Of course, Python isn’t the best choice for all kinds of programming projects. Python is often less effi cient than languages such as Java, C, and C++. So, for example, you wouldn’t use Python to create a new operat- ing system. But when you need to minimize the amount of time a programmer spends on a project, Python is often an excellent choice. 3