官术网_书友最值得收藏!

Helper Functions

A helper function performs part of the computation of another function. It allows you to reuse common code without repeating ourselves. For instance, suppose you had a few lines of code that printed out the elapsed time at various points in a function:

import time

def do_things():

    start_time = time.perf_counter()

    for i in range(10):

        y = i ** 100

        print(time.perf_counter() - start_time, "seconds elapsed")

    x = 10**2

    print(time.perf_counter() - start_time, "seconds elapsed")

    return x

   

do_things()

You should get the following output:

Figure 3.29: Timing our helper functions

The print statement is repeated twice in the preceding code, and will be better expressed as a helper function, as follows:

import time

def print_time_elapsed(start_time):

    print(time.perf_counter() - start_time, "seconds elapsed")

def do_things():

    start_time = time.perf_counter()

    for i in range(10):

        y = i ** 100

        print_time_elapsed(start_time)

    x = 10**2

    print_time_elapsed(start_time)

    return x

Don't Repeat Yourself

The preceding example encapsulates the Don't Repeat Yourself (DRY) programming principle. In other words, "Every piece of knowledge or logic must have a single, unambiguous representation within a system." If you want to do the same thing multiple times in your code, it should be expressed as a function, and called wherever it is needed.

Exercise 54: Helper Currency Conversion

In this exercise, you will take a function that computes the total USD for a transaction and use a helper function to apply the DRY principle. You also want to add an optional margin into the currency conversion that should default to 0:

def compute_usd_total(amount_in_aud=0, amount_in_gbp=0):

    total = 0

    total += amount_in_aud * 0.78

    total += amount_in_gbp * 1.29

    return total

compute_usd_total(amount_in_gbp=10)

You should get the following output:

12.9

  1. Create a currency conversion function with an optional margin:

    def convert_currency(amount, rate, margin=0):

         return amount * rate * (1 + margin)

  2. Modify the original function to use the helper function:

    def compute_usd_total(amount_in_aud=0, amount_in_gbp=0):

        total = 0

        total += convert_currency(amount_in_aud, 0.78)

        total += convert_currency(amount_in_gbp, 1.29)

        return total

  3. Check the result:

    compute_usd_total(amount_in_gbp=10)

    You should get the following output:

    12.9

  4. Suppose that the business has decided to add a 1% margin for the conversion of the GBP component. Modify the function accordingly:

    def compute_usd_total(amount_in_aud=0, amount_in_gbp=0):

        total = 0

        total += convert_currency(amount_in_aud, 0.78)

        total += convert_currency(amount_in_gbp, 1.29, 0.01)

        return total   

  5. Check the result:

    compute_usd_total(amount_in_gbp=10)

    You should get the following output:

    13.029

Note that it's possible to get ahead of yourself when applying the DRY principle in writing reusable code. In the currency example, if our application really did just require converting currency once, then it probably shouldn't be written as a separate function. It may be tempting to think that generalizing our code is always good because it insures us against the possibility of needing to repeat the same code later; however, this attitude is not always optimal. You can end up spending a lot of time writing more abstract code than is necessary, and, often, this code can be less readable and may introduce unnecessary complexity to our codebase. Typically, the time to apply the DRY principle is when you find yourself writing the code for the second time.

主站蜘蛛池模板: 新郑市| 济源市| 嘉义县| 大洼县| 新和县| 石棉县| 清涧县| 青海省| 留坝县| 长葛市| 灵山县| 英超| 安阳市| 祁门县| 自贡市| 景洪市| 宁强县| 庐江县| 延边| 鲜城| 张家川| 且末县| 达拉特旗| 辽中县| 临潭县| 贵州省| 漳州市| 武邑县| 连州市| 阜城县| 美姑县| 台州市| 上犹县| 西和县| 泽州县| 三穗县| 新平| 吉安县| 丘北县| 哈巴河县| 南华县|