氣泡圖是一種多變數的統計圖表,可以看作是散點圖的變形。
與散點圖不同的是,每一個氣泡都表示三個維度的資料,除了像散點圖一樣有X,Y軸,氣泡的大小可以表示另一個維度的資料。
例如,x軸表示產品銷量,y軸表示產品利潤,氣泡大小代表產品市場份額百分比。
它可以幫助我們發現變數之間的模式、趨勢和異常值。
通過氣泡的大小和顏色,我們可以同時比較多個變數的值,並且可以快速識別出具有較大或較小數值的資料點。
氣泡圖通常用於展示和比較資料之間的關係和分佈,可以展示三維(X,Y軸,氣泡大小),甚至四維資料(X,Y軸,氣泡大小,氣泡顏色)之間的關係。
它的主要元素包括:
氣泡圖適用的分析場景包括:
氣泡圖在以下情況可能不適用:
本次使用氣泡圖分析 2021年中歐之間的貿易資料情況。
氣泡圖可以分析三個維度的對比:
資料來源國家統計局公開的資料,整理好的資料可從下面的地址下載:
https://databook.top/nation/A06
用到的三個統計資料分別是:
A06050103.csv
A06050203.csv
A06050303.csv
fp = "d:/share/data/A06050103.csv"
df_total = pd.read_csv(fp)
fp = "d:/share/data/A06050203.csv"
df_output = pd.read_csv(fp)
fp = "d:/share/data/A06050303.csv"
df_input = pd.read_csv(fp)
資料清理步驟主要包括:
#提取每個檔案中2021年的資料
df = df_total[df_total["sj"] == 2021]
#去除中歐整體的交易額資料,只保留和各個國家之間的貿易資料
data = df.loc[2:, ["zbCN", "value"]]
#重新對映列的名稱
data = data.rename(columns={"zbCN":"country", "value": "total"})
#過濾多餘字元,生成一個表示國家的資料列
data["country"] = data["country"].str.replace("中國同", "", regex=False)
data["country"] = data["country"].str.replace("進出口總額(萬美元)", "", regex=False)
df = df_input[df_input["sj"] == 2021]
#合併進出口總額,進口額,出口額到一個資料集中
data["input"] = df.loc[2:, ["value"]]
df = df_output[df_output["sj"] == 2021]
#合併進出口總額,進口額,出口額到一個資料集中
data["output"] = df.loc[2:, ["value"]]
data.head(5)
和歐洲的總體交易資料位於每個資料集的第一行,所用用 loc[2:, ...]
來過濾。
with plt.style.context("seaborn-v0_8"):
fig = plt.figure()
ax = fig.add_axes([0.1, 0.1, 0.8, 0.8])
ax.scatter(
data["input"] / 10000,
data["output"] / 10000,
data["total"] / 10000,
c = np.random.rand(len(data)),
cmap="Accent",
alpha=0.6,
)
ax.set_xlabel("進口額(億元)")
ax.set_ylabel("出口額(億元)")
x = np.linspace(0, 1400, 7)
y = x
ax.plot(x, y, '-')
從圖中可以看出:
橫軸是進口額,縱軸是出口額,氣泡越大,進出口總額越大。
中間的藍色線表示進出口額度一樣,可以看出,大部分國家都在藍色線之上,
說明我國和大部分歐洲的貿易都是順差。
左下角有很多小氣泡,說明和大部分國家之間的進出口貿易額不高,也許是歐洲的小國家很多的緣故。