mirror of
https://github.com/pocketpy/pocketpy
synced 2026-02-09 09:00:22 +00:00
fix #447
This commit is contained in:
parent
cbbe319520
commit
d5b711f50c
@ -60,16 +60,18 @@ def filter(f, iterable):
|
|||||||
if f(i):
|
if f(i):
|
||||||
yield i
|
yield i
|
||||||
|
|
||||||
def zip(a, b):
|
class zip:
|
||||||
a = iter(a)
|
def __init__(self, *iterables):
|
||||||
b = iter(b)
|
self.iterables = [iter(it) for it in iterables]
|
||||||
while True:
|
|
||||||
try:
|
def __iter__(self):
|
||||||
ai = next(a)
|
return self
|
||||||
bi = next(b)
|
|
||||||
except StopIteration:
|
def __next__(self):
|
||||||
break
|
result = []
|
||||||
yield ai, bi
|
for it in self.iterables:
|
||||||
|
result.append(next(it))
|
||||||
|
return tuple(result)
|
||||||
|
|
||||||
def reversed(iterable):
|
def reversed(iterable):
|
||||||
a = list(iterable)
|
a = list(iterable)
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
@ -381,6 +381,21 @@ for x, y in zip(d, e):
|
|||||||
# verify that original order and values are retained.
|
# verify that original order and values are retained.
|
||||||
assertEqual(x is y, True)
|
assertEqual(x is y, True)
|
||||||
|
|
||||||
|
# https://github.com/pocketpy/pocketpy/issues/447
|
||||||
|
names = ["Alice", "Bob", "Charlie"]
|
||||||
|
ages = [25, 30, 35]
|
||||||
|
cities = ["NY", "LA", "SF"]
|
||||||
|
result = []
|
||||||
|
for name, age, city in zip(names, ages, cities):
|
||||||
|
result.append((name, age, city))
|
||||||
|
assertEqual(result, [("Alice", 25, "NY"), ("Bob", 30, "LA"), ("Charlie", 35, "SF")])
|
||||||
|
|
||||||
|
cities.pop()
|
||||||
|
result = []
|
||||||
|
for name, age, city in zip(names, ages, cities):
|
||||||
|
result.append((name, age, city))
|
||||||
|
assertEqual(result, [("Alice", 25, "NY"), ("Bob", 30, "LA")])
|
||||||
|
|
||||||
########### test repr#############
|
########### test repr#############
|
||||||
d = deque(range(200))
|
d = deque(range(200))
|
||||||
e = eval(repr(d))
|
e = eval(repr(d))
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user