
作者:俊欣
來源:關于數據分析與可視化
相信大家一定會seaborn或者matplotlib這幾個模塊感到并不陌生,通常大家會用這幾個模塊來進行可視化圖表的制作,為了讓我們繪制的圖表更具交互性,今天小編來給大家介紹個組件。
首先我們通過pip命令來下載該模塊
pip install ipywidgets
該模塊中的interact函數可以和我們自定義的函數相結合,隨著我們輸入的不斷變化,輸出也會產生相應的不同結果,我們來看一個簡單的案例
from ipywidgets import interact def f(x): print(f"The square value is: {x**2}")
interact(f, x=10)
output
當我們拖動當中的圓點的時候,輸出的結果也隨之變化。當然我們也可以將其當做是裝飾器來使用,代碼如下
@interact(x=10) def f(x): print(f"The square value is: {x**2}")
output
上面的自定義函數中,當然我們可以自行設定橫軸當中的最大值與最小值,以及每拖動一次x值的變化(和Python當中的range函數類似),
interact(f, x=widgets.IntSlider(min=-10, max=30, step=1, value=10))
output
而當輸入框中的參數不止一個參數的時候,可以有不止一個的滑動條,代碼如下
import ipywidgets as widgets
one = widgets.IntSlider(min = 0, max = 10)
two = widgets.IntSlider(min = 0, max = 100)
three = widgets.IntSlider(min = 0, max = 1000)
ui = widgets.HBox([one, two, three])
def func(x, y, z): print(f"The first value is: {x + 2}") print(f"The second value is: {y * 2}") print(f"The third value is: {z ** 2}")
out = widgets.interactive_output(func, {"x": one, "y": two, "z": three})
display(ui, out)
output
當參數類型是字符串時,則是需要通過輸入框的形式來進行交互,代碼如下
def f_2(x): print(f"The value is: {x}")
interact(f_2, x="Hello World")
output
而當我們輸入的X參數是一個列表里面有著若干個字符串的時候,則會在輸入框中出現個下拉框,如下所示
interact(f_2, x=["Hello World", "你好"])
output
然后我們來看看該模塊和seaborn之間的結合,我們先用Pandas模塊來讀取數據集,代碼如下
import pandas as pd
df = pd.read_csv("data.csv")
df.head()
output
我們簡單地來畫一張直方圖,代碼如下
import seaborn as sns import matplotlib.pyplot as plt
%matplotlib inline g = sns.countplot(data = df, x="Gender", hue="Attrition")
output
我們可以將繪制圖表的這一行代碼封裝成一個函數,將代碼中的“x”甚至是“hue”作為是輸入的參數,代碼如下
## 篩選出離散型變量的特征 categorical_columns = [column for column in df.columns if df[column].dtype == "object"] ## 做成下拉框的形式來進行交互 dd = widgets.Dropdown(options=categorical_columns, value=categorical_columns[0], description="Select a column") @interact(column=dd) def draw_countplot(column): g = sns.countplot(data = df, x=column, hue="Attrition")
output
我們可以在下拉框中選擇不同的離散型變量的特征從而繪制出不同的圖表,當然一個下拉框可能有人會覺得有點少,我們可以再來擴展一下
## 兩個下拉框 dd1 = widgets.Dropdown(options=categorical_columns, value=categorical_columns[0], description="Column")
dd2 = widgets.Dropdown(options=categorical_columns, value=categorical_columns[0], description="Hue")
ui = widgets.HBox([dd1, dd2]) ## 繪制圖表的函數 def draw_countplot(column, hue):
g = sns.countplot(data = df, x=column, hue=hue) ## X軸方向的標記會旋轉60度 if len(df[column].unique()) > 3:
g.tick_params(axis="x", rotation=60) out = widgets.interactive_output(draw_countplot, {'column':dd1, "hue": dd2}) ## 最終將圖表呈現出來 display(ui, out)
output
當然有可能會覺得都是輸入框的話會有點無聊,那我們在輸入框的同時加入一個滑動條,對應的是輸入的參數是整型或者是浮點數時
## 兩個輸入框還有一個滑動條 dd1 = widgets.Dropdown(options=numeric_columns, description="Column1")
dd2 = widgets.Dropdown(options=numeric_columns, description="Column2")
slider = widgets.IntSlider(min=df['Age'].min(), max=df["Age"].max(), description="Max Age")
ui = widgets.HBox([dd1, dd2, slider]) ## 繪制圖表的函數 def draw_relplot(column1, column2, age):
p = sns.relplot(data=df[df['Age']<=age], x=column1, y=column2) out = widgets.interactive_output(draw_countplot, {"column1": dd1, "column2": dd2, "age": slider}) ## 將最終的圖表給呈現出來 display(ui, out)
output
數據分析咨詢請掃描二維碼
若不方便掃碼,搜微信號:CDAshujufenxi
CDA數據分析師證書考試體系(更新于2025年05月22日)
2025-05-26解碼數據基因:從數字敏感度到邏輯思維 每當看到超市貨架上商品的排列變化,你是否會聯想到背后的銷售數據波動?三年前在零售行 ...
2025-05-23在本文中,我們將探討 AI 為何能夠加速數據分析、如何在每個步驟中實現數據分析自動化以及使用哪些工具。 數據分析中的AI是什么 ...
2025-05-20當數據遇見人生:我的第一個分析項目 記得三年前接手第一個數據分析項目時,我面對Excel里密密麻麻的銷售數據手足無措。那些跳動 ...
2025-05-20在數字化運營的時代,企業每天都在產生海量數據:用戶點擊行為、商品銷售記錄、廣告投放反饋…… 這些數據就像散落的拼圖,而相 ...
2025-05-19在當今數字化營銷時代,小紅書作為國內領先的社交電商平臺,其銷售數據蘊含著巨大的商業價值。通過對小紅書銷售數據的深入分析, ...
2025-05-16Excel作為最常用的數據分析工具,有沒有什么工具可以幫助我們快速地使用excel表格,只要輕松幾步甚至輸入幾項指令就能搞定呢? ...
2025-05-15數據,如同無形的燃料,驅動著現代社會的運轉。從全球互聯網用戶每天產生的2.5億TB數據,到制造業的傳感器、金融交易 ...
2025-05-15大數據是什么_數據分析師培訓 其實,現在的大數據指的并不僅僅是海量數據,更準確而言是對大數據分析的方法。傳統的數 ...
2025-05-14CDA持證人簡介: 萬木,CDA L1持證人,某電商中廠BI工程師 ,5年數據經驗1年BI內訓師,高級數據分析師,擁有豐富的行業經驗。 ...
2025-05-13CDA持證人簡介: 王明月 ,CDA 數據分析師二級持證人,2年數據產品工作經驗,管理學博士在讀。 學習入口:https://edu.cda.cn/g ...
2025-05-12CDA持證人簡介: 楊貞璽 ,CDA一級持證人,鄭州大學情報學碩士研究生,某上市公司數據分析師。 學習入口:https://edu.cda.cn/g ...
2025-05-09CDA持證人簡介 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度、美團、阿里等 ...
2025-05-07相信很多做數據分析的小伙伴,都接到過一些高階的數據分析需求,實現的過程需要用到一些數據獲取,數據清洗轉換,建模方法等,這 ...
2025-05-06以下的文章內容來源于劉靜老師的專欄,如果您想閱讀專欄《10大業務分析模型突破業務瓶頸》,點擊下方鏈接 https://edu.cda.cn/g ...
2025-04-30CDA持證人簡介: 邱立峰 CDA 數據分析師二級持證人,數字化轉型專家,數據治理專家,高級數據分析師,擁有豐富的行業經驗。 ...
2025-04-29CDA持證人簡介: 程靖 CDA會員大咖,暢銷書《小白學產品》作者,13年頂級互聯網公司產品經理相關經驗,曾在百度,美團,阿里等 ...
2025-04-28CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-27數據分析在當今信息時代發揮著重要作用。單因素方差分析(One-Way ANOVA)是一種關鍵的統計方法,用于比較三個或更多獨立樣本組 ...
2025-04-25CDA持證人簡介: 居瑜 ,CDA一級持證人國企財務經理,13年財務管理運營經驗,在數據分析就業和實踐經驗方面有著豐富的積累和經 ...
2025-04-25