在raw_input上使用Python的输入是否有用?

在raw_input上使用Python的输入是否有用?,第1张

在raw_input上使用Python的输入是否有用?

在raw_input上使用Python 2的输入是否有用?

没有。


input()
评估用户提供的代码。它将Python的全部功能掌握在用户手中。使用生成器表达式/列表推导,
__import__
if/else
运算符,实际上,Python可以用一个表达式来完成任何工作。恶意用户可以使用
input()
删除文件(
__import__('os').remove('precious_file')
),修补程序的其余部分(
setattr(__import__('__main__'),'function', lambda:42)
)等等。

普通用户不需要使用所有高级功能。如果不需要表达式,请使用

ast.literal_eval(raw_input())
–该
literal_eval
函数是安全的。

如果您是为高级用户编写的,请为他们提供一种更好的输入代码的方法。插件,用户模块等–具有完整的Python语法,而不仅仅是功能。

如果您完全确定自己知道自己在做什么,请说

eval(raw_input())
。在
eval
尖叫“我很危险的!”
到训练有素的眼睛。但是,很有可能您永远都不需要这个。


input()
是Python 3解决的旧设计错误之一。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5011075.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-14
下一篇 2022-11-14

发表评论

登录后才能评论

评论列表(0条)

保存