我花了很长时间研究如何让两个子图共享相同的y轴,并在Matplotlib中共享两个单色条.
正在发生的事情是,当我打电话给colorbar()在任一功能subplot1或者subplot2,它会自动缩放的情节使得彩条加的情节会适合进入"插曲"包围盒内部,造成两个并排侧地块是两个非常不同的大小.
为了解决这个问题,我尝试创建了第三个子图,然后我将其修改为不存在只有一个颜色条存在的图.唯一的问题是,现在这两个地块的高度和宽度是不均匀的,我无法弄清楚如何使它看起来没问题.
这是我的代码:
from __future__ import division
import matplotlib.pyplot as plt
import numpy as np
from matplotlib import patches
from matplotlib.ticker import NullFormatter
# SIS Functions
TE = 1 # Einstein radius
g1 = lambda x,y: (TE/2) * (y**2-x**2)/((x**2+y**2)**(3/2))
g2 = lambda x,y: -1*TE*x*y / ((x**2+y**2)**(3/2))
kappa = lambda x,y: TE / (2*np.sqrt(x**2+y**2))
coords = np.linspace(-2,2,400)
X,Y = np.meshgrid(coords,coords)
g1out = g1(X,Y)
g2out = g2(X,Y)
kappaout = kappa(X,Y)
for i in range(len(coords)):
for …Run Code Online (Sandbox Code Playgroud) 我正在尝试生成具有两种颜色的 3D 绘图。一种颜色表示大于零的值,另一种颜色表示小于零的值。我只是不知道如何在代码中实现这一点。
这是我当前的代码:
from mpl_toolkits.mplot3d import Axes3D
from matplotlib import cm
import matplotlib.pyplot as plt
import matplotlib.tri as mtri
import pandas as pd
import numpy as np
df = pd.DataFrame.from_csv('...temp\\3ddata.csv', sep = ',', index_col = False)
fig = plt.figure()
ax = fig.gca(projection='3d')
x = df['P']
y = df['T']
z = df['S']
ax.plot(x, y, zs= 0, zdir = 'z', c= 'r')
ax.scatter(x,y, z, c = 'b', s = 20)
ax.set_xlabel('Pressure (Bar)')
ax.set_zlabel('Residual subcooling (J*Kg-1*K-1')
ax.set_ylabel('Temperaure of LNG (K)')
plt.show()
Run Code Online (Sandbox Code Playgroud)
我已经阅读了一些示例,但无法将它们应用到我的数据中。是否可以用 …
我正在使用 matplotlib 绘制散射图,只是简单地测试几个示例代码,但无法显示颜色。只显示灰色。例如:
import numpy as np
import matplotlib.pyplot as plt
x = np.random.rand(100)
y = np.random.rand(100)
t = np.arange(100)
plt.scatter(x, y, c=t)
plt.show()
Run Code Online (Sandbox Code Playgroud)
这与之前关于散点图和颜色映射的问题完全相同。查看执行结果:

我的设置有什么问题吗?我正在使用 Jupyter python 3.x 版本。
谢谢!