Skip to main content

Best Python book for beginners

It's really surprisingly difficult for someone who has been programming for a long time to write about programming at a level appropriate for real beginners. The first time I taught a class full of beginners at Neumont, I tried to take things as slow as possible. Then I spent the next week covering the material from the first day even slower.
So when the UGIC asked me to recommend a book to get for the participants in the Introduction to Python, I looked at all the ones I could find, but they all either assumed too much existing knowledge or covered material that would just confuse a beginner. Often both. But then Michael Bernstein pointed me to Python for Dummies.
If you're looking to teach beginners, or you're a beginner yourself, Python for Dummies is by far the best option. There's a few sections that are strikingly inappropriate for a book at its level (new-style classes!?) but it's still much, much better than any of the other books on the market in this respect. As a bonus, it's also one of the few that covers Python 2.5.

Comments

Paul said…
I haven't read Python for Dummies, but wanted to suggest a favorite which converted me to Python: "How to Think Like a Computer Scientist, Learning Python"

It's free at ibiblio.org, here:

http://www.ibiblio.org/obp/thinkCSpy/

Like ESR, I had rejected Python a couple of times in the past because of what I saw as a radically different syntax (the whole indentation thing mainly) but after I read the foreward of this online book, I was hooked. After finishing the book, I was convinced. Python is a keeper--I gave up Java and Perl and haven't looked back (ymmv, and to each his own, and all that)

What's your take on HTTLACS as compared to Python for Dummies?
Jonathan Ellis said…
HTTLACS may be the best option that is freely available. However, as the title says, it does try to approach the subject with some rigor. Recursion is covered early and in some detail, for instance, and I know from experience that this tends to blow beginners' minds.

It also never really covers anything really Python-specific. This is fine for its purpose, but for practical use you'd want something that (eventually) covers things like list comprehensions, generators, etc.
Anonymous said…
I second your recommendation of "Python for Dummies" as a good intro book. It is right up at the top of my books for Python beginners at Amazon.
CecilSunkure said…
I haven't read that particular book either, but I have started with this book that is free online, and is targeted more towards creating games in Python with the Pygame engine. Here it is: http://inventwithpython.com/chapters/

I recently started up with this book, and am posting up my experiences with it in my own blog here: http://cecilsunkure.blogspot.com/

I actually highly recommend this book, it's tiered in such a way that seems perfect. The example code and projects in the book are also exceptionally useful for working on yourself. Since the example code is documented so extremely well, I am able to gain a pretty good understanding of every aspect of the code presented in the book. A must read for anyone interested into coding games.
Casey said…
You can easily learn Python by reading the official tutorial and then working through the Python Koans.

http://pythonprojectwatch.blogspot.com/2011/06/master-python-and-tdd-through-python.html
Anonymous said…
My personal favourite Python book is

The Quick Python Book

It's great for beginners

Popular posts from this blog

A week of Windows Subsystem for Linux

I first experimented with WSL2 as a daily development environment two years ago. Things were still pretty rough around the edges, especially with JetBrains' IDEs, and I ended up buying a dedicated Linux workstation so I wouldn't have to deal with the pain.  Unfortunately, the Linux box developed a heat management problem, and simultaneously I found myself needing a beefier GPU than it had for working on multi-vector encoding , so I decided to give WSL2 another try. Here's some of the highlights and lowlights. TLDR, it's working well enough that I'm probably going to continue using it as my primary development machine going forward. The Good NVIDIA CUDA drivers just work. I was blown away that I ran conda install cuda -c nvidia and it worked the first try. No farting around with Linux kernel header versions or arcane errors from nvidia-smi. It just worked, including with PyTorch. JetBrains products work a lot better now in remote development mod...

Python at Mozy.com

At my day job, I write code for a company called Berkeley Data Systems. (They found me through this blog, actually. It's been a good place to work.) Our first product is free online backup at mozy.com . Our second beta release was yesterday; the obvious problems have been fixed, so I feel reasonably good about blogging about it. Our back end, which is the most algorithmically complex part -- as opposed to fighting-Microsoft-APIs complex, as we have to in our desktop client -- is 90% in python with one C extension for speed. We (well, they, since I wasn't at the company at that point) initially chose Python for speed of development, and it's definitely fulfilled that expectation. (It's also lived up to its reputation for readability, in that the Python code has had 3 different developers -- in serial -- with very quick ramp-ups in each case. Python's succinctness and and one-obvious-way-to-do-it philosophy played a big part in this.) If you try it out, pleas...

Why PHP sucks

(July 8 2005) Apparently I got linked by some PHP sites, and while there were a few well-reasoned comments here I mostly just got people who only knew PHP reacting like I told them their firstborn was ugly. These people tended to give variants on one or more themes: All environments have warts, so PHP is no worse than anything else in this respect I can work around PHP's problems, ergo they are not really problems You aren't experienced enough in PHP to judge it yet As to the first, it is true that PHP is not alone in having warts. However, the lack of qualitative difference does not mean that the quantitative difference is insignificant. Similarly, problems can be worked around, but languages/environments designed by people with more foresight and, to put it bluntly, clue, simply don't make the kind of really boneheaded architecture mistakes that you can't help but run into on a daily baisis in PHP. Finally, as I noted in my original introduction, with PHP, ...