Dieser Artikel bietet eine einfache Einführung in die funktionale Programmiertechnologie in Python.
In Python sind Funktionen „erstklassige Bürger“. Das heißt, Funktionen sind anderen Datentypen wie int gleichgestellt.
So können wir Funktionen Variablen zuweisen, sie als Argumente an andere Funktionen übergeben, sie in anderen Datenstrukturen (z. B. Diktate) speichern und sie als Rückgabewerte anderer Funktionen zurückgeben.
Funktionen als Objekte behandeln
Da andere Datentypen (wie String, Liste und Int) Objekte sind, sind Funktionen auch Objekte in Python-Objekt. Schauen wir uns die Beispielfunktion foo an, die ihren eigenen Namen ausgibt:
def foo(): print("foo")
Da Funktionen Objekte sind, können wir die Funktion foo jeder Variablen zuweisen und diese Variable dann aufrufen. Beispielsweise können wir die Funktion der Variablen bar zuweisen:
bar = foo bar() #will print "foo" to the console
Die Anweisung bar = foo weist das von der Funktion foo referenzierte Objekt der Variablen bar zu.
Objekte als Funktionen behandeln
Wenn Objekte aufrufbar sind, sind sie dasselbe wie Funktionen, z. B. object(). Dies wird durch die Methode __call__ erreicht.
Das Beispiel sieht wie folgt aus:
class Greeter: def __init__(self, greeting): self.greeting = greeting def __call__(self, name): return self.greeting + " " + name
Jedes Mal, wenn wir ein Objekt der Greeter-Klasse konfigurieren, erstellen wir ein neues Objekt, das einen neuen Namen hat, der gerufen werden kann bei der Begrüßung. Wie unten gezeigt:
morning = Greeter("good morning") #creates the callable object morning("john") # calling the object #prints "good morning john" to the console
Der Grund, warum wir das Morgenobjekt aufrufen können, ist, dass wir die Methode __call__ in der Klassendefinition verwendet haben. Um zu überprüfen, ob das Objekt aufrufbar ist, verwenden wir die integrierte Funktion aufrufbar:
callable(morning) #true callable(145) #false. int is not callable.
Funktionen innerhalb der Datenstruktur
Funktionen sind wie andere Objekte und können innerhalb der Datenstruktur gespeichert werden. Zum Beispiel können wir ein Wörterbuch von int bis func erstellen. Dies ist praktisch, wenn ein int eine Abkürzung für den auszuführenden Schritt ist.
# store in dictionary mapping = { 0 : foo, 1 : bar } x = input() #get integer value from user mapping[x]() #call the func returned by dictionary access
Ähnlich können Funktionen in einer Vielzahl anderer Datenstrukturen gespeichert werden.
Funktionen als Parameter und Rückgabewerte verwenden
Funktionen können auch als Parameter und Rückgabewerte anderer Funktionen verwendet werden. Funktionen, die Funktionen als Eingabe- oder Rückgabefunktionen akzeptieren, werden als Funktionen höherer Ordnung bezeichnet und sind ein wichtiger Bestandteil der funktionalen Programmierung.
Funktionen höherer Ordnung verfügen über leistungsstarke Funktionen. Wie in „Eloquent JavaScript“ erklärt:
def iterate(list_of_items): for item in list_of_items: print(item)
def iterate_custom(list_of_items, custom_func): for item in list_of_items: custom_func(item)
def add(x, y): return x + y def sub(x, y): return x - y def mult(x, y): return x * y def calculator(opcode): if opcode == 1: return add elif opcode == 2: return sub else: return mult my_calc = calculator(2) #my calc is a subtractor my_calc(5, 4) #returns 5 - 4 = 1 my_calc = calculator(9) #my calc is now a multiplier my_calc(5, 4) #returns 5 x 4 = 20.
Verschachtelte Funktion
Funktionen können auch innerhalb anderer Funktionen sein. Intrinsische Funktionen sind nützlich beim Erstellen von Hilfsfunktionen, kleinen wiederverwendbaren Funktionen, die als Untermodule zur Unterstützung der Hauptfunktion dienen.
Wir können Hilfsfunktionen verwenden, wenn das Problem eine bestimmte Funktionsdefinition (Parametertyp oder -reihenfolge) erfordert. Dieser nicht-traditionelle Ansatz vereinfacht die Problemlösung erheblich, siehe zum Beispiel: http://www-inst.eecs.berkeley.edu/~cs61a/sp12/lectures/lect4-2x3.pdf. Angenommen, Sie möchten eine Fibonacci-Funktion fib(n) definieren, die nur einen Parameter n hat, und wir müssen die n-te Fibonacci-Zahl zurückgeben. Eine Möglichkeit, eine solche Funktion zu definieren, besteht darin, eine Hilfsfunktion zu verwenden, um die ersten beiden Terme der Fibonacci-Folge zu verfolgen (da die Fibonacci-Zahl die Summe der ersten beiden Zahlen ist).def fib(n): def fib_helper(fk1, fk, k): if n == k: return fk else: return fib_helper(fk, fk1+fk, k+1) if n <= 1: return n else: return fib_helper(0, 1, 1)
mult = lambda x, y: x * y mult(1, 2) #returns 2
事实上,它们通常具备隐式的返回语句(在上面的示例中,函数想表达 return x * y,不过我们省略了 lambda 函数中的显式返回语句)。
lambda 函数更加强大和精准,因为我们还可以构建匿名函数(即没有名称的函数):
(lambda x, y: x * y)(9, 10) #returns 90
当我们只需要一次性使用某函数时,这种方法非常方便。例如,当我们想填充字典时:
import collections pre_fill = collections.defaultdict(lambda: (0, 0)) #all dictionary keys and values are set to 0
接下来我们来看 Map、Filter 和 Reduce,以更多地了解 lambda。
Map
map 函数基于指定过程(函数)将输入集转换为另一个集合。这类似于上文提到的 iterate_custom 函数。例如:
def multiply_by_four(x): return x * 4 scores = [3, 6, 8, 3, 5, 7] modified_scores = list(map(multiply_by_four, scores)) #modified scores is now [12, 24, 32, 12, 20, 28]
在 Python 3 中,map 函数返回的 map 对象可被类型转换为 list,以方便使用。现在,我们无需显式地定义 multiply_by_four 函数,而是定义 lambda 表达式:
modified_scores = list(map(lambda x: 4 * x, scores))
当我们想对集合内的所有值执行某项操作时,map 函数很有用。
Filter
就像名称所显示的那样,filter 函数可以帮助筛除不想要的项。例如,我们想要去除 scores 中的奇数,那么我们可以使用 filter:
even_scores = list(filter(lambda x: True if (x % 2 == 0) else False, scores)) #even_scores = [6, 8]
由于提供给 filter 的函数是逐个决定是否接受每一个项的,因此该函数必须返回 bool 值,且该函数必须是一元函数(即只使用一个输入参数)。
Reduce
reduce 函数用于「总结」或「概述」数据集。例如,如果我们想要计算所有分数的总和,就可以使用 reduce:
sum_scores = reduce((lambda x, y: x + y), scores) #sum_scores = 32
这要比写循环语句简单多了。注意:提供给 reduce 的函数需要两个参数:一个表示正在接受检查的项,另一个表示所用运算的累积结果。
本文是关于函数式编程的一篇入门文章,虽然尽量完备地介绍了相关的知识,但并不是那么深入。如想了解更多,大家可以阅读以下资源:
Das obige ist der detaillierte Inhalt vonPython-Funktionsprogrammierung, lesen Sie einfach diesen Artikel!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!