numpy Python无法将sequence乘以'float'类型的非int

slmsl1lt  于 2023-03-30  发布在  Python
关注(0)|答案(1)|浏览(187)

我试着计算一个公式,npnumpy

Ds = pow(10,5)
D = np.linspace(0, pow(10,6), 100)
alpha=1.44
beta=0.44
A=alpha*(D/Ds)
L=1.65
buf2=L/4.343
buf=pow(-(alpha*[D/Ds]),beta)
value=exp(buf)

然后我将绘制这些数据,但我得到:

buf=pow(-(alpha*[D/Ds]),beta)
TypeError: can't multiply sequence by non-int of type 'float'

我该如何克服呢?

snz8szmq

snz8szmq1#

变更:

buf=pow(-(alpha*[D/Ds]),beta)

致:

buf=pow(-(alpha*(D/Ds)),beta)

这一点:

[D/Ds]

给你一个元素的列表。
但是这个:

alpha * (D/Ds)

在与alpha相乘之前计算除法。
您可以将列表乘以整数:

>>> [1] * 4
[1, 1, 1, 1]

但不是通过浮点数:

[1] * 4.0
TypeError: can't multiply sequence by non-int of type 'float'

因为列表中不能有部分元素。
括号可用于数学计算中的分组:

>>> (1 + 2) * 4
12

相关问题