# Chapter 19. The Goodies

One of my goals for this book has been to teach you as little Python as possible. When there were two ways to do something, I picked one and avoided mentioning the other. Or sometimes I put the second one into an exercise.

Now I want to go back for some of the good bits that got left behind. Python provides a number of features that are not really necessary—you can write good code without them—but with them you can sometimes write code that’s more concise, readable or efficient, and sometimes all three.

# Conditional Expressions

We saw conditional statements in “Conditional Execution”. Conditional statements are often used to choose one of two values; for example:

if x > 0: y = math.log(x) else: y = float('nan')

This statement checks whether `x`

is positive. If so, it computes `math.log`

. If not, `math.log`

would raise a `ValueError`

. To avoid stopping the program, we generate a “NaN”, which is a special floating-point value that represents “Not a Number”.

We can write this statement more concisely using a **conditional expression**:

y = math.log(x) if x > 0 else float('nan')

You can almost read this line like English: “`y`

gets log-`x`

if `x`

is greater than 0; otherwise it gets NaN”.

Recursive functions can sometimes be rewritten using conditional expressions. For example, here is a recursive version of `factorial`

:

def factorial(n): if n == 0: return 1 else: return n * factorial(n-1)

We can rewrite it like this:

def factorial(n): return 1 if n == 0 else n * factorial(n-1)

Another use ...

Get *Think Python, 2nd Edition* now with the O’Reilly learning platform.

O’Reilly members experience live online training, plus books, videos, and digital content from nearly 200 publishers.