在Python中,`is not int`是否返回false?
我正在使用参数解析器来允许将端口号传递给我的程序。然后我尝试验证该值,第一个测试是在Python中,`is not int`是否返回false?,python,argparse,Python,Argparse,我正在使用参数解析器来允许将端口号传递给我的程序。然后我尝试验证该值,第一个测试是is int测试: parser = argparse.ArgumentParser(description='Provides XML-RPC API.') parser.add_argument('--port', dest='port', default=9666, type=int, help='port to listen on, 9666 b
is int
测试:
parser = argparse.ArgumentParser(description='Provides XML-RPC API.')
parser.add_argument('--port', dest='port', default=9666, type=int,
help='port to listen on, 9666 by default.');
args = parser.parse_args()
if args.port is not int:
raise TypeError("Port must be integer (%s given), use -h argument to get help."%(type(args.port).__name__))
if args.port>=65536 or args.port<=0:
raise IndexError("Port must be lower than 65536, 65535 is the maximum port number. Also, port can only be positive, non-zero number. Use -h argument to get help.")
if args.port<=1204:
print("Notice: ports up to 1024 are reserved to well known services, using this port numbers often leads to conflicts. Use -h argument to get help.")
我是说,到底怎么了?即使错误显示为int,那么发生了什么?
args.port不是int
如果args.port
被设置为int
类型,则返回False
:
args.port = int
args.port is int # True
或者将int
绑定到同一对象args。端口已绑定到:
int = args.port
args.port is int # True
这是因为is
测试两个引用是否指向完全相同的对象
也许您对如何测试对象的类型感到困惑,因为您使用了,或者测试了以下对象的输出:
这种情况也不会发生,因为您将ArgumentParser
选项配置为仅接受整数:
parser.add_argument('--port', dest='port', default=9666, type=int,
help='port to listen on, 9666 by default.')
type=int
参数很重要,因为这意味着解析器将拒绝任何不能解释为整数的内容。您将永远无法通过语法分析器。这里的parse_args()
:
>>> import argparse
>>> parser = argparse.ArgumentParser(description='Provides XML-RPC API.')
>>> parser.add_argument('--port', dest='port', default=9666, type=int,
... help='port to listen on, 9666 by default.')
_StoreAction(option_strings=['--port'], dest='port', nargs=None, const=None, default=9666, type=<type 'int'>, choices=None, help='port to listen on, 9666 by default.', metavar=None)
>>> parser.parse_args(['--port', 'not an integer'])
usage: [-h] [--port PORT]
: error: argument --port: invalid int value: 'not an integer'
您可以提供自己的对话功能来限制范围:
def portnumber(value):
port = int(value) # may raise ValueError
if not 0 <= port <= 65536:
raise ValueError('Not a valid port number')
return port
通常,通过isinstance(args.port,int)
测试某个对象是否为int
。但是,这里不需要此检查,因为argparse将保证它是一个整数。如果没有指定默认值,None
也有可能,但这里不是这样,因为您指定了默认值。'int'指的是类本身如果传递类“int”本身,则“is not int”将计算为False,这是不可能发生的。您可能希望改为“isinstance(args.port,int)”。不是int
将始终返回True
,除非执行int不是int
。这是因为is
是一个身份测试,这意味着它检查两个参数是否是同一个对象
假设你试过了
>>> 1 is not int
这将返回True
,因为1
与int
不是同一个对象。我们可以更深入地检查这一点
>>> type(1)
<class 'int'>
正如其他答案所建议的那样
你也可以这样做
type(args.port) is not int
检查args.port
的类型是否为int
您的意思是isinstance(args.port,int)
阅读此答案:啊,谢谢。我是初学者,所以我只是误解了是什么意思。还有,“如果它呱呱叫,那就是鸭子!”也就是鸭子打字。如果您收到了<代码> int <代码>,那么如果引发了异常,则捕获异常。那样更像是“蟒蛇”。
parser.add_argument('--port', dest='port', default=9666, type=portnumber,
help='port to listen on, 9666 by default.')
>>> 1 is not int
>>> type(1)
<class 'int'>
not isinstance(args.port, int)
type(args.port) is not int