10/27/2020: Real code!

A collection of notes to go over in class, to keep things organized.

Lightning Talks

Up today:

From last week:

Jason Emmett Hill

And then:

Jimmy Nguyen

Brian H Wong

Arielle Waller (Ari)

Erik J Knighton

Are you ready? We’ll do them in the middle of the lesson.

Issues that came up during the week.

MS Teams

Are you all on it?

gitHub “Failures”

Sorry about that – that’s a “linter”, set up to check style issues. I’ve turned it off for teh next few assignments.

main or master?

the default branch for git (and gitHub) used be called master. Soyou will see a LOT of docs talking abou tthe master branch. But gitHub now uses “main” for the default branch. Most of our TEmplate repos for the class were created before they made the switch, so the default branch is called “master”. But you may start seeing “main” used too.

The key point is that he name of the branch is arbitrary, the only special about “main” or “master” is that it is the default branch. Other than that, it, or any other branch, could be called anything.

git chaos!

If you have somethign wierd going on with git, there are a few options:

  • Google it – there is a LOT of infomation about git online.

  • Too much information, we have some git hints that might help you out of a jam for this class:

https://uwpce-pythoncert.github.io/ProgrammingInPython/topics/01-setting_up/git_hints.html

If all else fails:

One of the great things about git is that is a “distributed” version control system. That means that every copy (clone) of a repository has all teh information in it. And what that means is that if the clone on your workstation gets in a mess – you can smiply make another clone from gitHub and start again. If you move or rename the old (confused) one – then all the files in it will still be there, so you can copy any of your work that had not been pushed to gitHub over to the new clone.

git commit and PR messages

At this poiint, it’s pretty obvious what you are doing. But as the projects get more complicated, it won’t be.

So please put meaningful commit and PR messages – particularly PR messages!

This is a really good habit to get into for future development work.

PEP08 and a linter

It is a really good idea to get in the habit of using consistent style in your code – i.e. follow PEP08.

And this is really easy to do if you have a linter set up in your editor. If you haven’t gotten that to work – do try to do so soon!

https://www.python.org/dev/peps/pep-0008/

Even more important that all of that:

Use four spaces per indent

ALWAYS

What’s a docstring ?

if __name__ == __main__

What’s that all about?

Note: There’s a video in Lesson 2 – anyone still confused?

What is a range() object?

What does range actually create? Let’s check it out!

triple quoted strings or comments?

It’s not a good practice to use triple qluoted streings to “comment out” blocks of code.

Use comments:

# this is a line of code # and this is another # and one more.

Your editor / IDE should make that easy!

Separation of Concerns

From print_grid: if you are going to have separate functions, better for them to return a string, and then put all the printing in the calling function, in one place. That would make it more re-usable – say you want to write to a file?

This is a tiny example of what’s known as “separation of concerns”

for vs while

Quite a few folks used a while loop in print_grid, and sum_series, and …

But for all these cases, a for loop (and range()) is a better option.

So: When to use for vs while ?

  • You can do everything with a while loop – you never actually need for

But:

for is pretty handy primarily for looping through the items in an iterable – doing the similar things to everything in a collection.

And range() is an easy-to-create collection of a sequence of integers of a given size.

So in short:

Use while when you want to repeat something some unknown number of times – maybe a few times maybe thousands…

Use for when you want to work with an entire collection, or a pre-determined number of loops.

is vs ==

In FizzBuzz, someone had code something like this:

` if n % 3 is 0: `

That works, but it’s a “Bad Idea™”

“is” tests whether the objects are actually the same object – not whether they have the same value. As you can easily have multiple objects that happen to have the same value, “is” will fail in the general case.

But why did it work there?

This works because cpython has an optimization called “interning” – since small integers are used so often, the interpreter keeps a pool of them around to re-use, rather than creating multiple integer objects with the same value.

So “is” will work as a test for small integers, but not large ones:

In [65]: x = 5

In [66]: y = 5

In [67]: x is y
Out[67]: True

In [68]: x = 345678

In [69]: y = 345678

In [70]: x is y
Out[70]: False

NOTE: This is also the case for small strings.

Important: This is an implementation detail. Do not count on it!

Lightning Talks

Let’s take a break and do some of the lightning talks…

Jason Hill

Jimmy Nguyen

Brian H Wong

Review Solutions

I’ve posted my solutions to last week’s assignments in the class repo:

git pull

They are in:

solutions/Lesson02

But before we do that – code review / refactoring:

Angela – can we look at your code?

Coding Bat

Anyone get stuck on any and want to give it a look?

Lightning Talks

Let’s take a break and do the rest of the lightning talks…

Ari Waller

Erik J Knighton

Now some new stuff

Labs:

Get a start on your own, then we’ll come together and finish it up.

Slicing Lab

List Lab

String Formatting Exercise

Mailroom

Let’s start this as a group:

Mailroom