Я пытаюсь создать приведенный ниже генератор, чтобы иметь возможность устанавливать верхний предел возвращаемых чисел.
Вызов list(it.take while(lambda x: x < 100, get_primes())) возвращает список всех простых чисел до 100, как и ожидалось, но list(get_primes(100)) (который должен возвращать тот же список таким же образом) просто возвращает пустой list.
Очевидно, я мог бы включить if n и Candidate>=n: Break в цикл for, но меня больше всего интересует, почему конструкция if n: return не работает так, как я ожидал. Разве он не должен просто возвращать тот же итератор take while, который работает выше? Что я здесь упускаю?
import itertools as it
def get_primes(n=None):
"""
Generates primes to a max of n.
>>> list(get_primes(100))
[2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]
"""
if n:
return it.takewhile(lambda x: x < n, get_primes())
composites = {}
yield 2
for candidate in it.count(3, 2):
prime_factor = composites.pop(candidate, None)
if prime_factor is None:
yield candidate
composites[candidate**2] = candidate
else:
composite = candidate + 2*prime_factor
while composite in composites:
composite += 2*prime_factor
composites[composite] = prime_factor
Подробнее здесь: https://stackoverflow.com/questions/262 ... empty-list
Делегирование другому генератору с использованием «возврата» приводит к пустому списку ⇐ Python
Программы на Python
1762638538
Anonymous
Я пытаюсь создать приведенный ниже генератор, чтобы иметь возможность устанавливать верхний предел возвращаемых чисел.
Вызов list(it.take while(lambda x: x < 100, get_primes())) возвращает список всех простых чисел до 100, как и ожидалось, но list(get_primes(100)) (который должен возвращать тот же список таким же образом) просто возвращает пустой list.
Очевидно, я мог бы включить if n и Candidate>=n: Break в цикл for, но меня больше всего интересует, почему конструкция if n: return не работает так, как я ожидал. Разве он не должен просто возвращать тот же итератор take while, который работает выше? Что я здесь упускаю?
import itertools as it
def get_primes(n=None):
"""
Generates primes to a max of n.
>>> list(get_primes(100))
[2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]
"""
if n:
return it.takewhile(lambda x: x < n, get_primes())
composites = {}
yield 2
for candidate in it.count(3, 2):
prime_factor = composites.pop(candidate, None)
if prime_factor is None:
yield candidate
composites[candidate**2] = candidate
else:
composite = candidate + 2*prime_factor
while composite in composites:
composite += 2*prime_factor
composites[composite] = prime_factor
Подробнее здесь: [url]https://stackoverflow.com/questions/26206422/delegating-to-another-generator-using-return-results-in-empty-list[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия