Python中的树图可视化

22

我想绘制一个矩形树图

treemap example

什么是在Python中制作一个最简单的方法?是否有一个库可以根据正确的输入数据生成这样的图形?


4
七年之后,仍然荒谬的是没有一个像样的 Python 包能够绘制简单的树状图。下面列出的答案仍然是最先进的,但并不是很有帮助。用 R 或 js 只需要两行代码就可以完成,但是为什么在 Python 中会如此复杂?我不理解。 - MERose
2
实际上有squarify,它使得这非常容易:https://python-graph-gallery.com/200-basic-treemap-with-python/ - Nickolay
4个回答

5

您可以使用以下两种方法:

1)Pygal

它很简单:http://www.pygal.org/en/stable/documentation/types/treemap.html

2)squarify

使用 matplotlib 作为绘图 API。 示例代码:

import matplotlib
import matplotlib.pyplot as plt
import pandas as pd
import squarify

# qualtities plotted
# squarre area is the town surface area (superf)
# color scale is the town population in 2011 (p11_pop)

# read data from csv file
# data from CAPP opendata http://opendata.agglo-pau.fr/index.php/fiche?idQ=27
df = pd.read_excel("Customer Success New.xlsx")
df = df.set_index("location_id")
df = df[["user_id", "company_id"]]
df2 = df.sort_values(by="user_id", ascending=False)

# treemap parameters
x = 0.
y = 0.
width = 100.
height = 100.
cmap = matplotlib.cm.viridis

# color scale on the population
# min and max values without Pau
mini, maxi = df2.company_id.min(), df2.company_id.max()
norm = matplotlib.colors.Normalize(vmin=mini, vmax=maxi)
colors = [cmap(norm(value)) for value in df2.company_id]
colors[1] = "#FBFCFE"

# labels for squares
#labels = ["hab" % (label) for label in zip(df2.index, df2.user_id), df2.company_id)]
#labels[11] = "MAZERES" % (df2["user_id"]["MAZERES-LEZONS"], df2["company_id"]["MAZERES-LEZONS"])

# make plot
fig = plt.figure(figsize=(12, 10))
fig.suptitle("Population et superficie des communes de la CAPP", fontsize=20)
ax = fig.add_subplot(111, aspect="equal")
ax = squarify.plot(df2.superf, color=colors, label=labels, ax=ax, alpha=.7)
ax.set_xticks([])
ax.set_yticks([])
ax.set_title("L'aire de chaque carré est proportionnelle à la superficie de la commune\n", fontsize=14)

# color bar
# create dummy invisible image with a color map
img = plt.imshow([df2.p11_pop], cmap=cmap)
img.set_visible(False)
fig.colorbar(img, orientation="vertical", shrink=.96)

fig.text(.76, .9, "Population", fontsize=14)
fig.text(.5, 0.1,
         "Superficie totale %d km2, Population de la CAPP : %d hab" % (df2.superf.sum(), df2.p11_pop.sum()),
         fontsize=14,
         ha="center")
fig.text(.5, 0.07,
         "Source : http://opendata.agglo-pau.fr/",
         fontsize=14,
         ha="center")

plt.show()

好的,谢谢你们两个的反馈,我会更新我的答案。 - Nabih Ibrahim Bawazir
@NabihIbrahimBawazir的回答看起来好多了,感谢您的更新! - g00glen00b


3

Matlab方法实际上是一个SciPy菜谱,可在http://scipy-cookbook.readthedocs.io/items/Matplotlib_TreeMap.html获取。 - MERose

2

1
文档记录不完善。无法推荐他们。 - MERose

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接