我有一个变量,该变量可能是Sympy类。我想将其转换为浮标,但我很难以一般的方式进行此操作:
$ python
Python 2.7.3 (default, Dec 18 2014, 19:10:20)
[GCC 4.6.3] on linux2
>>> import sympy
>>> x = sympy.sqrt(2)
>>> type(x)
<class 'sympy.core.power.Pow'>
>>> y = 1 + x
>>> type(y)
<class 'sympy.core.add.Add'>
>>> z = 3 * x
>>> type(z)
<class 'sympy.core.mul.Mul'>
>>> if isinstance(z, sympy.core):
... z = z.evalf(50) # 50 dp
...
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: isinstance() arg 2 must be a class, type, or tuple of classes and types
我将测试x
,y
,z
以转换为浮点。请注意,我不能仅在x
,y
和z
上运行evalf()
,而无需检查,因为它们可能已经是整数或浮标,这会引起异常。
sympy.sympify()
不幸的是不会转换为float。如果这样做,那将是我问题的理想解决方案:
>>> sympy.sympify(z)
3*sqrt(2)
>>> type(sympy.sympify(z))
<class 'sympy.core.mul.Mul'>
所有sympy对象都从 sympy.Basic
继承。要通过数值评估Sympy表达式,只需使用.n()
In [1]: import sympy
In [2]: x = sympy.sqrt(2)
In [3]: x
Out[3]: sqrt(2)
In [4]: x.n()
Out[4]: 1.41421356237310
In [5]: if (isinstance(x, sympy.Basic)):
...: print(x.n())
...:
1.41421356237310
heh,归根结底,事实证明,您只需使用Python的本机浮点转换功能将Sympy对象转换为float!不知道为什么我没有直接尝试...
>>> import sympy
>>> x = sympy.sqrt(2)
>>> float(x)
1.4142135623730951
我会使用它,因为即使 x
是python int或已经是python float