python colorbar xtick locator_python matplotlib colorbar设置tick formator/locator更改tick标签

我刚找到解决办法。必须打电话bar.update_ticks()

更改格式化程序/定位程序后,请参见

然后一切正常。

更新:

这也是更改格式化程序/定位程序的代码。它基于彩色条码的内部结构,所以也许其他人有更好的解决方案:#http://matplotlib.sourceforge.net/examples/pylab_examples/griddata_demo.html

from numpy.random import uniform, seed

from matplotlib.mlab import griddata

import matplotlib.pyplot as plt

import matplotlib.ticker

import numpy as np

# make up data.

seed(0)

npts = 200

x = uniform(-2,2,npts)

y = uniform(-2,2,npts)

z = x*np.exp(-x**2-y**2)

# define grid

xi = np.linspace(-2.1,2.1,100)

yi = np.linspace(-2.1,2.1,200)

# grid the data.

zi = griddata(x,y,z,xi,yi,interp='linear')

##### PLOT

plt.figure()

CS = plt.contour(xi,yi,zi,25,cmap=plt.cm.jet)

bar = plt.colorbar(orientation='horizontal') # draw colorbar

tick_locs = [-3.9e-1,-2.6e-1,-1.3e-1,0e-1,1.3e-1,2.6e-1,3.9e-1]

tick_labels = ['-0.390','-0.260','-0.130','0','0.13','0.26','0.390']

bar.locator = matplotlib.ticker.FixedLocator(tick_locs)

bar.formatter = matplotlib.ticker.FixedFormatter(tick_labels)

bar.update_ticks()

# plot data points.

#plt.scatter(x,y,marker='o',c='b',s=5,zorder=10)

plt.xlim(-2,2)

plt.ylim(-2,2)

plt.title('griddata test (%d points)' % npts)

plt.show()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将Matplotlib中的contourf图形的colorbar放在下方,可以使用subplot()函数创建一个包含两个子图的figure对象,一个子图用于绘制contourf图形,另一个子图用于绘制colorbar。 下面是一个示例代码: ```python import matplotlib.pyplot as plt import numpy as np # 生成数据 x = np.linspace(-3, 3, 301) y = np.linspace(-3, 3, 301) X, Y = np.meshgrid(x, y) Z = np.sin(np.sqrt(X**2 + Y**2)) # 创建figure对象和两个子图 fig, (ax1, ax2) = plt.subplots(nrows=1, ncols=2, figsize=(8, 4)) # 绘制contourf图形 cf = ax1.contourf(X, Y, Z, cmap='coolwarm') ax1.set_xlabel('X') ax1.set_ylabel('Y') ax1.set_title('Contourf Plot') # 绘制colorbar cbar = plt.colorbar(cf, ax=ax1, orientation='horizontal', shrink=0.8, pad=0.15) cbar.ax.set_xlabel('Z') cbar.ax.tick_params(labelsize=8) # 在另一个子图中绘制一些其他的图形 ax2.plot(x, np.sin(x), label='sin(x)') ax2.plot(x, np.cos(x), label='cos(x)') ax2.set_xlabel('X') ax2.set_ylabel('Y') ax2.set_title('Other Plot') ax2.legend() plt.show() ``` 在这个示例代码中,我们首先使用np.meshgrid()函数生成了一个二维的网格数据,然后使用contourf()函数绘制了一个contourf图形,并将其放在了第一个子图中。接着,我们使用colorbar()函数在第一个子图的右边绘制了一个水平方向的colorbar,并设置了一些参数,如缩放比例和位置等。最后,在第二个子图中我们绘制了一些其他的图形,如sin(x)和cos(x)。 使用这种方式可以方便地将contourf图形和colorbar放在同一个figure中,并且可以灵活地控制它们的位置和样式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值