Python is one of the most popular programming languages for beginners, making it the most widely taught language in schools around the world.
However, learning Python is not an easy thing. To get started, you first need to find the best online way to get there, which is difficult in itself. There are thousands of different Python courses and tutorials, all claiming to be the best.
True, practice alone is not perfect, but perfect practice is. This means that you need to make sure that you are always following the best coding practices (commenting on your code, using correct syntax, etc.), otherwise you will likely end up adopting bad habits that could harm your future lines of code.
In this article, I’m going to give my top 10 tips to help you code in Python quickly and efficiently.
First of all, try to make your programs easy to read by following some programming conventions. A programming convention is one that a seasoned programmer follows when writing his or her code. There’s no quicker way to reveal that you’re a “newbie” than by ignoring conventions. Some of these conventions are specific to Python; others are used by computer programmers in all languages.
Essentially, readability is the characteristic which specifies how easy another person can understand some parts of your code (and not you!).
As an example, I was not used to write with vertical alignment and to align the function’s parameters with opening delimiter.
# No, to avoid:
func = long_function_name(var_one, var_two,
var_three, var_four)
#Yes,
func = long_function_name(var_one, var_two,
var_three, var_four)
Look at other examples in the Style Guide for Python Code and decide what looks best.
Another important thing that we do very often is resembling programs that we have seen or written before, which is why our exposure to readable programs is important in learning programming.
Often, a long if & elif & …. & else conditions is the sign of code that needs refactoring, these conditions make your code lengthy and really hard to interpret. Sometimes they can easily be replaced, for example, I used to do the following:
def f():
if condition:
return True
else:
return False
This is just dumb! The function is returning a boolean, so why even use if blocks in the first place? The correct what of doing this would be:
def f():
return condition
In a Hackerrank challenge, you are given the year and you have to write a function to check if the year is leap or not. In the Gregorian calendar three criteria must be taken into account to identify leap years:
So in this challenge, forget about ifs and elses and just do the following:
def is_leap(year):
return year % 4 == 0 and (year % 400 == 0 or year % 100 != 0)
def function(key, value=0):
"""Return a dictionary and a list..."""
d = {key: value}
l = [key, value]
return d, l
The docstrings explain how to use the code :
The comments explain what are for the maintainers of your code. Examples including notes for yourself, such as:
!!! BUG: …
!!! FIX: This is a hack
??? Why is this here?
It is on your responsibility to write good docstrings and good comments, so always keep them up to date! When making changes, make sure the comments and docstrings are consistent with the code.
You will find a detailed PEP dedicated for Doctsrings : “Docstring Conventions”
In other programming languages :
c = a
a = b
b = c
In Python, it’s better to use the assignment in one line code :
b, a = a, b
You may have already seen it but do you know how it works?
Other examples:
>>> user =['Jan', 'Gomez', '+1-888-222-1546']
>>> name, title, phone = user
>>> name
'Jan'
>>> title
'Gomez'
>>> phone
'+1-888-222-1546'
Useful in loops on structured data (the variable user above has been kept):
>>> people = [user, ['German', 'GBT', 'unlisted']]
>>> for (name, title, phone) in people:
... print (name, phone)
...
Jan +1-888-222-1546
German unlisted
It is also possible to do the opposite way, just make sure you have the same structure on the right and on the left:
>>> jan, (gname, gtitle, gphone) = people
>>> gname
'German'
>>> gtitle
'GBT'
>>> gphone
'unlisted'
>>> jan
['Jan', 'Gomez', '+1-888-222-1546']
Let’s start with a list of strings:
colors = ['red', 'blue', 'green', 'yellow']
We want to concatenate these chains together to create a long one. Particularly when the number of substrings is large, avoid doing this :
result = ''
for s in colors:
result += s
It is very slow. It uses a lot of memory and performance. The sum will add up, store, and then move on to each intermediate step.
Instead, do this:
result = ''.join(colors)
The join () method makes the entire copy in one pass. When you only process a few strings, it makes no difference. But get into the habit of building your chains optimally, because with hundreds or thousands strings, it will truly make a difference.
Here are some techniques for using the join () method. If you want a space as a separator:
result = ' '.join(colors)
or a comma and a space:
result = ', '.join(colors)
To make a grammatically correct sentence, we want commas between each value except the last one, where we prefer an “or”. The syntax for splitting a list does the rest. The [: -1] returns everything except the last value, which we can concatenate with our commas.
colors = ['red', 'blue', 'green', 'yellow']
print ('Choose', ', '.join(colors[:-1]), \
'or', colors[-1])
>> Choose red, blue, green or yellow
It is elegant and quick to take advantage of Python with regard to Boolean values:
# Do this : # And not this :
if x: if x == True:
pass pass
# Do this : # And not this :
if items: if len(items) != 0:
pass pass
# and especially not that :
if items != []:
pass
The enumerate function takes a list and returns pairs (index, item):
items = ['zero', 'one', 'two', 'three']
>>> print list(enumerate(items))
[(0, 'zero'), (1, 'one'), (2, 'two'), (3, 'three')]
It is necessary to use a list to display the results because enumerate is a lazy function, generating one item (a pair) at a time, only when requested. A for loop requires such a mechanism. Print does not take one result at a time but must be in possession of the entire message to be displayed. We therefore automatically converted the generator to a list before using print.
So, using the loop below is much better:
for (index, item) in enumerate(items):
print (index, item)
# compared to : # And :
index = 0 for i in range(len(items)):
for item in items: print (i, items[i])
print (index, item)
index += 1
The version with enumerate is shorter and simpler than the two other versions. An example showing that the enumerate function returns an iterator (a generator is a kind of iterator)
The traditional way with for and if:
new_list = []
for item in a_list:
if condition(item):
new_list.append(fn(item))
Using a list comprehension:
new_list = [fn(item) for item in a_list if condition(item)]
The listcomps are clear and direct. You can have several for loops and if conditions within the same listcomp, but beyond two or three, or if the conditions are complex, I suggest you use the usual for loop.
For example, the list of squares from 0 to 9:
>>> [n ** 2 for n in range(10)]
[0, 1, 4, 9, 16, 25, 36, 49, 64, 81]
The list of odd numbers within the previous list:
>>> [n ** 2 for n in range(10) if n % 2]
[1, 9, 25, 49, 81]
Another example:
>>> [(x, y) for x in (1, 2, 3, 4) if x % 2 == 0
for y in ['a', 'b'] if y == 'b']
[(2, 'b'), (4, 'b')]
Let’s sum the squares of numbers less than 100:
# With a loop :
total = 0
for num in range(1, 101):
total += num * num
We can also use the sum function which does the job faster for us by building the right sequence.
# With a list comprehension :
total = sum([num * num for num in range(1, 101)])
# With a generator expression :
total = sum(num * num for num in xrange(1, 101))
The generator expressions are like list comprehensions, except in their calculation, they are lazy. Listcomps calculate the entire result in a single pass, to store it in a list. Generator expressions calculate one value at a time, when necessary. This is particularly useful when the sequence is very long and the generated list is only an intermediate step and not the final result.
For example if we have to sum the squares of several billion integers, we will reach a saturation of the memory with a list comprehension, but the generator expressions will not have any problem. Well it will take a while though!
total = sum(num * num for num in range(1, 1000000000))
The difference in syntax is that listcomps have square brackets, while generator expressions do not. Generator expressions sometimes require parentheses, so you should always use them.
In short :
In this article, I have presented some of my best tips for learning to program in Python. If you really want to become a programmer or add a coding skill to your skills, learning Python is a great place to start. Look for high quality Python training online and start to find out how to program in Python. I recommend that you learn the basics with an interactive course before moving on to more difficult concepts.
You should not speed up the learning process too much, or you may miss important information. Take notes and make sure to review them regularly and try to practice writing code as often as possible.
Connect with colleagues who are learning like you and don’t be afraid to ask questions when you have them. Helping others when they have problems can be a great review, and working with someone else’s code is a great way to learn new things.
If you do all of this, nothing can stop you! So what are you waiting for? Start programming in Python now!
Thank you!
#python #coding #programming