내가 할 수 있는 파이썬 3 다음 (참조 PEP3132 의 확장됨 이트레이블 꺼내기):
a, *b = (1, 2, 3)
# a = 1; b = (2, 3)
What can I do) 을 달성할 수 있는 것과 마찬가지로 우아한 파이썬 2.x?
a, b = (1, 2, 3)[0], (1, 2, 3)[1:]
# a = 1; b = (2, 3)
난 몇 가지 예를 들면 PEP3132 에 대해 관련 있다는 것을 밝혀냈다 파이썬 2.x 잘 알려져 있다.
>. 많은 경우, 최초의 알고리즘은 분할 시퀀스일 받을시간은 ", rest". 페어당:
>. 첫째, 미삭 = 시퀀스 [0], 시퀀스 [1:]
>. [.]
>. 또한 오른쪽 값이 없는 경우, 하지만 한 이트레이블 바뀌엇어요 변환되도록 발견되기 전까지 바뀌엇어요 분할 할 수 있다. 이 제품을 만들지 않도록 수단으로 이 임시 목록
>. it = 국제열핵융합실험로 (seq.) >. 첫 번째 = 아그네스트 () >. 미삭 = 목록 (it)
추가로 필요한 함수 정의 / 문의:
def unpack(first, *rest):
return first, rest
first, rest = unpack( *seq )
왜 그랬을까 구현되는 것이 아니라 일반 튜플 압축 풀기 위한 열거합니다 압축 해제 기능을 인수.
크레딧. 사용자 정의 함수 구축현 있어야 합니다. 이에 대해 좀 더 유연한 com/go/4e6b330a_kr first 수가 있다.
def unpack_nfirst(seq, nfirst):
it = iter(seq)
for x in xrange(nfirst):
yield next(it, None)
yield tuple(it)
first, rest = unpack_nfirst(seq, 1)
def just(n, seq):
it = iter(seq)
for _ in range(n - 1):
yield next(it, None)
yield tuple(it)
예를 들면 다음과 같습니다.
a, b, c = just(3, range(5))
print a, b, c
## 0 1 (2, 3, 4)
또한 적은. 작동됨 인수만:
a, b, c = just(3, ['X', 'Y'])
print a, b, c
## X Y ()
셀명 대한 응답으로 정의할 수도 있습니다.
def take2(a, *rest): return a, rest
def take3(a, b, *rest): return a, b, rest
def take4(a, b, c, *rest): return a, b, rest
... etc
그리고 이를 사용하여 다음과 같습니다.
p = (1,2,3)
a, b = take2(*p)
print a, b
## 1 (2, 3)