Yield라는 영어 단어는 Production을 의미합니다. 저는 Python을 처음 접했을 때 매우 혼란스러웠고, Yield를 어떻게 사용하는지 전혀 알지 못했습니다.
저는 다음 예와 같이 Yield를 사용하여 함수의 반환 값에 데이터를 넣을 수 있다는 것을 대략적으로 알고 있습니다.
def addlist(alist): for i in alist: yield i + 1
alist의 각 항목을 꺼낸 다음 i + 1을 그 안에 넣습니다. 그런 다음 다음을 호출하여 각 항목을 꺼냅니다.
alist = [1, 2, 3, 4] for x in addlist(alist): print x,
이것은 실제로 Yield 애플리케이션의 예입니다
1. Yield가 포함된 함수
Yield가 포함된 함수가 표시되면 이 함수는 이미 생성기임을 의미합니다. 다른 일반적인 기능과는 매우 다릅니다. 예를 들어 다음과 같은 간단한 함수는 다음과 같습니다.
def h(): print 'To be brave' yield 5 h()
h()를 호출한 후 print 문이 실행되지 않는 것을 볼 수 있습니다! 이것이 Yield인데, print 문을 어떻게 실행하게 할까요? 이는 나중에 논의할 문제입니다. 이후의 논의와 연구를 통해 Yield가 어떻게 작동하는지 이해하게 될 것입니다.
2. Yield는 표현식입니다.
Python 2.5 이전에는 Yield가 명령문이었지만 이제 Python 2.5에서는 Yield가 다음과 같은 표현식(Expression)입니다.
m = Yield 5
expression (yield 5 ) m에 할당되므로 m = 5라고 생각하는 것은 잘못된 것입니다. 그렇다면 (수율 5)의 반환 값을 얻는 방법은 무엇입니까? 나중에 소개할 send(msg) 메소드를 사용해야 합니다.
3. next()문을 통해 원리를 살펴보세요
이제 Yield의 작동 원리를 공개하겠습니다. 우리는 위의 h()가 항복 표현식을 가지고 있기 때문에 호출된 후에 실행되지 않았다는 것을 알고 있으므로 next() 문을 통해 실행되도록 했습니다. next() 문은 다음 항복 표현식이 나올 때까지 Generator 실행을 재개합니다. 예:
def h(): print 'Wen Chuan' yield 5 print 'Fighting!' c = h() c.next()
c.next()가 호출된 후 h()는 Yield 5를 만날 때까지 실행을 시작하므로 출력 결과는 다음과 같습니다.
Wen Chuan
c.next()를 다시 호출하면 실행은 다음과 같습니다. 다음 항복 표현식을 찾을 때까지 계속합니다. 나중에 Yield가 없으므로 예외가 발생합니다:
Wen Chuan Fighting! Traceback (most recent call last): File "/home/evergreen/Codes/yidld.py", line 11, in <module> c.next() StopIteration
4.send(msg) 및 next()
next()가 Yield를 포함하는 함수를 실행하는 방법을 이해한 후 또 다른 매우 중요한 함수를 살펴보겠습니다. (메시지)를 보냅니다. 실제로 next()와 send()는 어떤 의미에서는 유사한 기능을 가지고 있습니다. 차이점은 send()는 항복 표현식의 값을 전달할 수 있는 반면, next()는 특정 값을 전달할 수 없으며 None만 전달할 수 있다는 것입니다. 따라서
c.next()와 c.send(None)가 동일한 효과를 가짐을 알 수 있습니다.
이 예를 보세요:
def h(): print 'Wen Chuan', m = yield 5 # Fighting! print m d = yield 12 print 'We are together!' c = h() c.next() #相当于c.send(None) c.send('Fighting!') #(yield 5)表达式被赋予了'Fighting!'
출력 결과는 다음과 같습니다:
Wen Chuan Fighting!
처음 호출할 때는 next() 문을 사용하거나 send(None)를 사용할 수 없습니다. send를 사용하여 None 이외의 값을 보냅니다. 그렇지 않으면 이 값을 받을 수 있는 Yield 문이 없기 때문에 오류가 발생합니다.
5. send(msg)와 next()
send(msg)와 next()의 반환 값은 매우 특별합니다. 예를 들어, 생산량이 5이면 5가 반환됩니다. 여기서 뭔가 이해가 되셨나요? 이 기사의 첫 번째 예에서는 alist의 for i를 통해 Generator를 순회함으로써 alist.Next()가 실제로 매번 호출되고, 매번 alist.Next()의 반환 값은 Yield의 매개 변수입니다. 우리는 그것이 뭔가가 눌려져 있다고 생각하기 시작합니다. 위의 예를 계속 진행해 보겠습니다.
def h(): print 'Wen Chuan', m = yield 5 # Fighting! print m d = yield 12 print 'We are together!' c = h() m = c.next() #m 获取了yield 5 的参数值 5 d = c.send('Fighting!') #d 获取了yield 12 的参数值12 print 'We will never forget the date', m, '.', d
출력 결과:
Wen Chuan Fighting! We will never forget the date 5 . 12
6.throw() 및 close()가 Generator를 중단합니다.
Generator를 중단하는 것은 매우 유연한 기술입니다. GeneratorExit 예외를 발생시킵니다. Close() 메서드에는 실제로 내부적으로 throw(GeneratorExit)를 호출하는 것과 동일한 기능이 있습니다. 살펴보겠습니다:
def close(self): try: self.throw(GeneratorExit) except (GeneratorExit, StopIteration): pass else: raise RuntimeError("generator ignored GeneratorExit") # Other exceptions are not caught
따라서 close() 메서드를 호출한 다음 next() 또는 send(msg)를 호출하면 예외가 발생합니다.
Traceback (most recent call last): File "/home/evergreen/Codes/yidld.py", line 14, in <module> d = c.send('Fighting!') #d 获取了yield 12 的参数值12 StopIteration
위 내용은 수익률에 대한 자세한 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!