PyQt4에서 슬롯과 신호 간의 연결을 설정하는 것은 이벤트 처리의 기본 측면입니다. 그러나 루프 내의 버튼에서 발생하는 여러 신호를 연결하려고 하면 예기치 않은 동작이 발생할 수 있습니다.
이 문제를 설명하려면 다음 코드를 고려하세요.
def __init__(self): for i in range(0, 10): self._numberButtons = [QPushButton(str(i), self)] self.connect(self._numberButtons[i], SIGNAL('clicked()'), lambda: self._number(i)) def _number(self, x): print(x)
버튼 중 하나를 클릭하면 어떤 버튼을 눌렀는지에 관계없이 출력에 일관되게 '9'가 표시됩니다. 이 동작 뒤에 있는 이유를 이해하려면 Python의 범위 지정 규칙의 복잡성을 탐색해야 합니다.
Python에서 변수의 범위 지정은 가장 가까운 엔클로징 함수에 의해 결정됩니다. 이 예에서는 람다 함수와 '_number' 함수가 모두 '__init__' 함수 내에 정의되어 있습니다. 루프는 각 반복마다 'i'에 동일한 값('9')을 할당하므로 람다 함수는 항상 '__init__' 함수 내에서 'i'에 할당된 마지막 값인 '9'를 캡처합니다.
이 문제를 해결하기 위한 한 가지 접근 방식은 'i'를 람다 함수 내의 기본값과 함께 키워드 인수로 전달하여 각 인스턴스에 대해 별도의 'i' 바인딩이 생성되도록 하는 것입니다.
self._numberButtons[i].clicked.connect(lambda checked, i=i: self._number(i))
또는 functools.partial을 사용하여 'i'를 각 버튼과 연관된 특정 값.
self._numberButtons[i].clicked.connect(partial(self._number, i))
이러한 수정은 각 콜백 함수가 올바른 값을 캡처하도록 보장합니다. 버튼 클릭에 대한 적절한 응답을 가능하게 합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3