Python matplotlib颜色栏标记标签格式
我想知道如何在matplotlib中显式设置colorbar对象的格式 下面是一个打印脚本示例:Python matplotlib颜色栏标记标签格式,python,text,matplotlib,plot,colorbar,Python,Text,Matplotlib,Plot,Colorbar,我想知道如何在matplotlib中显式设置colorbar对象的格式 下面是一个打印脚本示例: from matplotlib import pyplot from matplotlib.ticker import MultipleLocator, FormatStrFormatter from matplotlib.colors import BoundaryNorm from matplotlib.ticker import MaxNLocator from pylab import *
from matplotlib import pyplot
from matplotlib.ticker import MultipleLocator, FormatStrFormatter
from matplotlib.colors import BoundaryNorm
from matplotlib.ticker import MaxNLocator
from pylab import *
import numpy as np
import random
# ----------
plot_aspect = 1.2
plot_height = 10.0
plot_width = int(plot_height*plot_aspect)
# ----------
pyplot.figure(figsize=(plot_width, plot_height), dpi=100)
pyplot.subplots_adjust(left=0.10, right=1.00, top=0.90, bottom=0.06, hspace=0.30)
subplot1 = pyplot.subplot(111)
# ----------
cbar_max = 40.0
cbar_min = 20.0
cbar_step = 1.0
cbar_num_colors = 200
cbar_num_format = "%d"
# ----------
# make random dataset
dx, dy = 5.0, 5.0
y, x = np.mgrid[slice(-100.0, 100.0 + dy, dy),slice(-100.0, 100.0 + dx, dx)]
z = []
for i in x:
z.append([])
for j in y:
z[-1].append(random.uniform(cbar_min,cbar_max))
# ----------
# make random dataset
levels = MaxNLocator(nbins=cbar_num_colors).tick_values(cbar_min, cbar_max)
cmap = pyplot.get_cmap('gist_ncar')
norm = BoundaryNorm(levels, ncolors=cmap.N, clip=True)
pp = pyplot.contourf(x,y,z,levels=levels,cmap=cmap)
cbar = pyplot.colorbar(pp, orientation='vertical', ticks=np.arange(cbar_min, cbar_max+cbar_step, cbar_step), format=cbar_num_format)
cbar.ax.set_ylabel('Color Scale [unit]', fontsize = 16, weight="bold")
CS = pyplot.contour(x,y,z, alpha=0.5)
majorLocator1 = MultipleLocator(10)
majorFormatter1 = FormatStrFormatter('%d')
minorLocator1 = MultipleLocator(5)
subplot1.xaxis.set_major_locator(majorLocator1)
subplot1.xaxis.set_major_formatter(majorFormatter1)
subplot1.xaxis.set_minor_locator(minorLocator1)
pyplot.xticks(fontsize = 16)
pyplot.xlim(-100.0,100.0)
majorLocator2 = MultipleLocator(10)
majorFormatter2 = FormatStrFormatter('%d')
minorLocator2 = MultipleLocator(5)
subplot1.yaxis.set_major_locator(majorLocator2)
subplot1.yaxis.set_major_formatter(majorFormatter2)
subplot1.yaxis.set_minor_locator(minorLocator2)
pyplot.yticks(fontsize = 16)
pyplot.ylim(-100.0,100.0)
subplot1.xaxis.grid()
subplot1.yaxis.grid()
subplot1.axes.set_aspect('equal')
pyplot.suptitle('Main Title', fontsize = 24, weight="bold")
pyplot.xlabel('X [unit]', fontsize=16, weight="bold")
pyplot.ylabel('Y [unit]', fontsize=16, weight="bold")
pyplot.show()
pyplot.close()
这给了我这样的输出:
当前,colorbar勾号标签格式将使用前面提供的格式字符串:cbar\u num\u format=“%d”
,但我还想使用以下方法设置字体大小和重量:
cbar.ax.set_yticklabels(np.arange(cbar_min, cbar_max+cbar_step, cbar_step), fontsize=16, weight='bold')
…但当我执行此操作时,以前应用的格式化程序字符串似乎消失了,数字返回到%0.1f
格式,而不是我先前应用的%d”
:
如何防止这种情况发生或以更好的方式控制colorbar勾号标签?一个选项是手动设置勾号标签的格式。也许有更好的方法,但这通常对我有效
cbar.ax.set_yticklabels(['{:.0f}'.format(x) for x in np.arange(cbar_min, cbar_max+cbar_step, cbar_step)], fontsize=16, weight='bold')
编辑:
如果您不想自己计算滴答声,可以使用:
for l in cbar.ax.yaxis.get_ticklabels():
l.set_weight("bold")
l.set_fontsize(16)
如果未正确更新,则可能需要调用draw()
。这可以减少为一个衬里,包括:
setp(cbar.ax.yaxis.get_ticklabels(), weight='bold', fontsize=16)
只是把它改成
cbar.ax.set_yticklabels(np.arange(int(cbar_min), int(cbar_max+cbar_step), int(cbar_step)), fontsize=16, weight='bold')
做的诀窍
i、 e.只需将int()
赋给np.arange()
中的cbar.ax.set\yticklabels
在这里,我将色条刻度格式化为百分比
import numpy as np
import matplotlib.pyplot as plt
xs = np.linspace(0, 1, 20)
ys = xs ** 3
colors = xs ** 2
scatter = plt.scatter(xs, ys, c=colors)
cb = plt.colorbar(scatter)
cb.ax.set_yticklabels(["{:.1%}".format(i) for i in cb.get_ticks()]) # set ticks of your format
plt.show()
您还可以手动设置刻度位置
ticks = np.linspace(0, 1, 5)
cb = plt.colorbar(scatter, ticks=ticks)
cb.ax.set_yticklabels(["{:.1%}".format(i) for i in ticks]) # set ticks of your format
对于这个示例,我使用了python3.7
,matplotlib 3.1.2
更好的解决方案是
from matplotlib.ticker import FuncFormatter
fmt = lambda x, pos: '{:.1%}'.format(x)
cbar = plt.colorbar(format=FuncFormatter(fmt))
这确实有效,但我希望它是灵活的,并将格式作为输入。不过,谢谢!['{.0f}'。中x的格式(x)似乎不起作用,但中x的格式(x)起作用了!可能是版本差异?可能是版本差异。您使用的python版本是什么?我使用的是版本2.6.6