我有一个图,在对数刻度中使用颜色条,如下图所示。 我正在使用cmap='RdBu_r'并且我希望值1为白色,但是,颜色cmap='RdBu_r'的白色接近于值2.8。 谁能告诉我该如何调整? 码: ...
提示:本站收集StackOverFlow近2千万问答,支持中英文搜索,鼠标放在语句上弹窗显示对应的参考中文或英文, 本站还提供 中文繁体 英文版本 中英对照 版本,有任何建议请联系yoyou2525@163.com。
我正在尝试为不同系列创建一个具有不同颜色的情节。 当我尝试将图中的数据添加为文本框时,出现了问题。
我使用的代码如下:
import pandas as pd
import matplotlib.pyplot as plt
import seaborn as sns
import numpy as np
import scipy.stats as stats
df = pd.DataFrame({'x': [21000, 16900, 18200, 32000, 35000, 7500], 'y':[3000, 2100, 1500, 3000, 2500, 2000], 'z':['a', 'b', 'c', 'd', 'e', 'f']})
fig, ax = plt.subplots(figsize=(8,6))
text_list = []
color_list = []
for i, row in df.iterrows():
mu, sigma, group = row['x'], row['y'], row['z']
x = np.linspace(mu - 4*sigma, mu + 4*sigma, 100)
sns.lineplot(x, stats.norm.pdf(x, mu, sigma), ax=ax)
color = ax.get_lines()[-1].get_c()
ax = plt.gca()
ax.text(mu*1.05, max(stats.norm.pdf(x, mu, sigma)), group, fontsize=16, color=color) #only retrieve RGB so blank text is not too light
text = r'{0}: {1} $\pm$ {2}'.format(group, mu, sigma)
text_list.append(text)
color_list.append(color)
plt.gcf().text(0.68, 0.6, '\n'.join(text_list), bbox=dict(facecolor='white', edgecolor='black', pad=10.0, alpha=1), fontsize=14)
fig.show()
bbox中的文本均为黑色。 理想情况下,文本框中的每条线应具有与图中相应系列相同的颜色。
我能够在text_box_content和color_list中保存两个文本和颜色列表。 我还尝试在具有动态更新的文本位置的for循环中添加plt.gcf().text()
,但是为每行创建了边框,而不是为所有文本创建了整体边框。
如果在概念上有类似的东西会更好
plt.gcf().text(zip(text_list, color_list))
所以每行可以有自己的颜色吗?
您可以创建图例,并通过其所属行的颜色为每个图例项上色。 如果您不想在图例中显示该行本身,则可以显示相应的字母作为图例句柄。
import pandas as pd
import matplotlib.pyplot as plt
from matplotlib.legend_handler import HandlerBase
from matplotlib.text import Text
import seaborn as sns
import numpy as np
import scipy.stats as stats
class TextHandler(HandlerBase):
def create_artists(self, legend,tup ,xdescent, ydescent,
width, height, fontsize,trans):
tx = Text(width/2.,height/2,tup[0], fontsize=fontsize,
ha="center", va="center", color=tup[1], fontweight="bold")
return [tx]
df = pd.DataFrame({'x': [21000, 16900, 18200, 32000, 35000, 7500],
'y':[3000, 2100, 1500, 3000, 2500, 2000],
'z':['a', 'b', 'c', 'd', 'e', 'f']})
fig, ax = plt.subplots(figsize=(8,6))
handles = []
labels = []
for i, row in df.iterrows():
mu, sigma, group = row['x'], row['y'], row['z']
x = np.linspace(mu - 4*sigma, mu + 4*sigma, 100)
sns.lineplot(x, stats.norm.pdf(x, mu, sigma), ax=ax)
color = ax.get_lines()[-1].get_c()
ax.text(mu*1.05, max(stats.norm.pdf(x, mu, sigma)), group, fontsize=16, color=color)
handles.append(("{}:".format(group), color))
labels.append("{} $\pm$ {}".format(mu, sigma))
leg = ax.legend(handles=handles, labels=labels, handler_map={tuple : TextHandler()},
facecolor='white', edgecolor='black', borderpad=0.9, framealpha=1,
fontsize=10, handlelength=0.5)
for h, t in zip(leg.legendHandles, leg.get_texts()):
t.set_color(h.get_color())
plt.show()
这是受到我对这个问题的回答的启发并部分使用了代码,在您不想使用图例的情况下,它也提供了另一种选择。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.