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

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.

主站蜘蛛池模板: 福泉市| 都江堰市| 额尔古纳市| 托克逊县| 九寨沟县| 舒城县| 武宣县| 紫金县| 台州市| 水城县| 宜丰县| 泽州县| 鲁甸县| 清水河县| 祥云县| 淮安市| 南投市| 桃源县| 四子王旗| 富平县| 花莲县| 灵丘县| 剑阁县| 黔西| 宝丰县| 韩城市| 湄潭县| 汶川县| 从江县| 错那县| 阿图什市| 长阳| 宁晋县| 同德县| 曲靖市| 凉山| 锡林浩特市| 阜阳市| 南漳县| 托克逊县| 乃东县|