मैं एक कंटेनर जो सभी रूढ़ अंक (वास्तव में एक memoised जानवर बल प्रधानमंत्री परीक्षण खाल)अजगर एक अनंत सेट से विकल्पों argparse
import math
def is_prime(n):
if n == 2 or n == 3:
return True
if n == 1 or n % 2 == 0:
return False
else:
return all(n % i for i in xrange(3, int(1 + math.sqrt(n)), 2))
class Primes(object):
def __init__(self):
self.memo = {}
def __contains__(self, n):
if n not in self.memo:
self.memo[n] = is_prime(n)
return self.memo[n]
यही लगता है के सेट की तरह व्यवहार का दिखावा बनाने के लिए निम्नलिखित कोड है अब तक काम करने:
>>> primes = Primes()
>>> 7 in primes
True
>>> 104729 in primes
True
>>> 100 in primes
False
>>> 100 not in primes
True
लेकिन यह अच्छी तरह से argparse
के साथ खेल नहीं है:
>>> import argparse as ap
>>> parser = ap.ArgumentParser()
>>> parser.add_argument('prime', type=int, choices=primes, metavar='p')
_StoreAction(option_strings=[], dest='prime', nargs=None, const=None, default=None, type=<type 'int'>, choices=<__main__.Primes object at 0x7f4e21783f10>, help=None, metavar='p')
>>> parser.parse_args(['7'])
Namespace(prime=7)
>>> parser.parse_args(['11'])
Namespace(prime=11)
>>> parser.parse_args(['12'])
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/usr/lib/python2.7/argparse.py", line 1688, in parse_args
args, argv = self.parse_known_args(args, namespace)
File "/usr/lib/python2.7/argparse.py", line 1720, in parse_known_args
namespace, args = self._parse_known_args(args, namespace)
File "/usr/lib/python2.7/argparse.py", line 1929, in _parse_known_args
stop_index = consume_positionals(start_index)
File "/usr/lib/python2.7/argparse.py", line 1885, in consume_positionals
take_action(action, args)
File "/usr/lib/python2.7/argparse.py", line 1778, in take_action
argument_values = self._get_values(action, argument_strings)
File "/usr/lib/python2.7/argparse.py", line 2219, in _get_values
self._check_value(action, value)
File "/usr/lib/python2.7/argparse.py", line 2267, in _check_value
tup = value, ', '.join(map(repr, action.choices))
TypeError: argument 2 to map() must support iteration
docs सिर्फ इतना कहना है कि
किसी भी वस्तु का समर्थन करता है कि ऑपरेटर में विकल्प के रूप में पारित किया जा सकता मूल्य, इसलिए dict वस्तुओं, सेट वस्तुओं, कस्टम कंटेनर, आदि सभी समर्थित हैं।
स्पष्ट रूप से मैं प्राइम के अनंत "सेट" को फिर से शुरू नहीं करना चाहता हूं। तो क्यों बिल्ली argparse
map
मेरी primes की कोशिश कर रहा है? क्या इसे सिर्फ in
और not in
की आवश्यकता नहीं है?
धन्यवाद, मैंने एक मुद्दा बनाया है जैसा आपने सुझाव दिया [यहां] (http://bugs.python.org/issue16697)। – wim