Muh*_*sif 3 python data-visualization matplotlib data-science
使用此代码生成相关表:
df1.drop(['BC DataPlus', 'AC Glossary'], axis=1).corr(method='pearson').style.format("{:.2}").background_gradient(cmap=plt.get_cmap('coolwarm'), axis=1)
Run Code Online (Sandbox Code Playgroud)
我找不到任何方法将此表另存为图像。谢谢你。
如果从字面上看,你提出的问题很难回答。困难源于df.style.render()
生成 HTML 然后将其发送到浏览器以呈现为图像的事实。结果在所有浏览器中也可能不完全相同。
Python 不直接参与图像的生成。所以没有直接的基于 Python 的解决方案。
尽管如此,在Pandas 开发人员的 github 页面上提出了如何将 HTML 转换为 png 的问题,
建议的答案是使用phantomjs
. 其他方式(我还没有测试过)可能是使用
webkit2png
或
GrabzIt。
然而,如果我们放松对问题的解释,我们就可以避免大部分困难。df.style
我们可以使用seaborn非常轻松地生成类似的图像,而不是尝试生成由(针对特定浏览器)生成的精确图像:
import numpy as np
import pandas as pd
import seaborn as sns
import matplotlib.pyplot as plt
df = pd.DataFrame(np.random.random((6, 4)), columns=list('ABCD'))
fig, ax = plt.subplots()
sns.heatmap(df.corr(method='pearson'), annot=True, fmt='.4f',
cmap=plt.get_cmap('coolwarm'), cbar=False, ax=ax)
ax.set_yticklabels(ax.get_yticklabels(), rotation="horizontal")
plt.savefig('result.png', bbox_inches='tight', pad_inches=0.0)
Run Code Online (Sandbox Code Playgroud)
如果您不想添加 seaborn 依赖项,您可以直接使用 matplotlib,尽管它需要多几行代码:
import colorsys
import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
df = pd.DataFrame(np.random.random((6, 4)), columns=list('ABCD'))
corr = df.corr(method='pearson')
fig, ax = plt.subplots()
data = corr.values
heatmap = ax.pcolor(data, cmap=plt.get_cmap('coolwarm'),
vmin=np.nanmin(data), vmax=np.nanmax(data))
ax.set_xticks(np.arange(data.shape[1])+0.5, minor=False)
ax.set_yticks(np.arange(data.shape[0])+0.5, minor=False)
ax.invert_yaxis()
row_labels = corr.index
column_labels = corr.columns
ax.set_xticklabels(row_labels, minor=False)
ax.set_yticklabels(column_labels, minor=False)
def _annotate_heatmap(ax, mesh):
"""
**Taken from seaborn/matrix.py**
Add textual labels with the value in each cell.
"""
mesh.update_scalarmappable()
xpos, ypos = np.meshgrid(ax.get_xticks(), ax.get_yticks())
for x, y, val, color in zip(xpos.flat, ypos.flat,
mesh.get_array(), mesh.get_facecolors()):
if val is not np.ma.masked:
_, l, _ = colorsys.rgb_to_hls(*color[:3])
text_color = ".15" if l > .5 else "w"
val = ("{:.3f}").format(val)
text_kwargs = dict(color=text_color, ha="center", va="center")
# text_kwargs.update(self.annot_kws)
ax.text(x, y, val, **text_kwargs)
_annotate_heatmap(ax, heatmap)
plt.savefig('result.png', bbox_inches='tight', pad_inches=0.0)
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6115 次 |
最近记录: |