我想绘制电子的偏转,当我编译程序时它没有显示任何图形。 这是我到目前为止的代码,注释代表 SI 单位。
import matplotlib.pyplot as plt
v=25300000 # m/s
E=1000 # V/m
d=10 # m
m=9*pow(10,-31) #kg
q=1.6*pow(10,-19) # C
for i in range(0,d):
y=(q*E*i*i)/(2*m*v*v)
plt.plot(i,y)
plt.xlabel("x")
plt.ylabel("y")
plt.show()
最佳答案
plt.plot
需要多个点(除非您指定标记),因此
plt.plot(i,y)
当i
和y
是单独的值时,仅当它们是数组或类似数组的对象时,才不会生成图表。您可以将其替换为 plt.scatter
,
import matplotlib.pyplot as plt
v=25300000 # m/s
E=1000 # V/m
d=10 # m
m=9*pow(10,-31) #kg
q=1.6*pow(10,-19) # C
for i in range(0,d):
y=(q*E*i*i)/(2*m*v*v)
plt.scatter(i,y)
plt.xlabel("x")
plt.ylabel("y")
plt.show()
这会给你
或者创建 y
和 x
值的列表,
y = []
x = []
for i in range(0, d):
y.append((q*E*i*i)/(2*m*v*v))
x.append(i)
plt.plot(x,y)
或者,更好的是,使 x
和 y
numpy 数组:
import numpy as np
# ...
x = np.arange(0,10)
y = (q*E*x**2)/(2*m*v*v)
plt.plot(x,y)
其中任何一个都会给你
关于python - 用python绘制电容器板之间的电子偏转,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59813726/