相关疑难解决方法(0)

为什么使用'eval'是一种不好的做法?

我正在使用以下课程轻松存储我的歌曲数据.

class Song:
    """The class to store the details of each song"""
    attsToStore=('Name', 'Artist', 'Album', 'Genre', 'Location')
    def __init__(self):
        for att in self.attsToStore:
            exec 'self.%s=None'%(att.lower()) in locals()
    def setDetail(self, key, val):
        if key in self.attsToStore:
            exec 'self.%s=val'%(key.lower()) in locals()
Run Code Online (Sandbox Code Playgroud)

我觉得这比写出一个if/else块更具可扩展性.但是,eval似乎被认为是一种不良做法并且使用起来不安全.如果是这样,任何人都可以向我解释为什么并告诉我一个更好的方法来定义上面的类?

python eval

125
推荐指数
6
解决办法
3万
查看次数

将分数转换为浮点数?

有点像这个问题,但相反.

给定一个串像1,1/2或者1 2/3,什么是将其转换成一个浮动的最好方法?我正在考虑逐个使用正则表达式,但也许有人知道更好的方法,或者预先存在的解决方案.我希望我可以使用eval,但我认为第三种情况可以防止这种情况发生.

python parsing

23
推荐指数
3
解决办法
2万
查看次数

标签 统计

python ×2

eval ×1

parsing ×1