成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

使用Bokeh為你的Python繪圖添加交互性

開發 后端
在這一系列文章中,我通過在每個 Python 繪圖庫中制作相同的多條形繪圖,來研究不同 Python 繪圖庫的特性。這次我重點介紹的是 Bokeh(讀作 “BOE-kay”)。

[[330736]]

在 Bokeh 中繪圖比其他一些繪圖庫要復雜一些,但付出額外的努力是有回報的。

在這一系列文章中,我通過在每個 Python 繪圖庫中制作相同的多條形繪圖,來研究不同 Python 繪圖庫的特性。這次我重點介紹的是 Bokeh(讀作 “BOE-kay”)。

Bokeh 中的繪圖比其它一些繪圖庫要復雜一些,但付出的額外努力是有回報的。Bokeh 的設計既允許你在 Web 上創建自己的交互式繪圖,又能讓你詳細控制交互性如何工作。我將通過給我在這個系列中一直使用的多條形圖添加工具提示來展示這一點。它繪制了 1966 年到 2020 年之間英國選舉結果的數據。

 

繪圖的放大視圖(©2019 年 Anvil

制作多條形圖

在我們繼續之前,請注意你可能需要調整你的 Python 環境來讓這段代碼運行,包括以下:

  • 運行最新版本的 Python (在 LinuxMac 和 Windows 上的說明)
  • 確認你運行的 Python 版本能與這些庫一起工作。

數據可在線獲得,可以用 Pandas 導入。

  1. import pandas as pd
  2. df = pd.read_csv('https://anvil.works/blog/img/plotting-in-python/uk-election-results.csv')

現在我們可以繼續進行了。

為了做出多條形圖,你需要對你的數據進行一下調整。

原始數據是這樣的:

  1. >> print(long)
  2. year party seats
  3. 0 1966 Conservative 253
  4. 1 1970 Conservative 330
  5. 2 Feb 1974 Conservative 297
  6. 3 Oct 1974 Conservative 277
  7. 4 1979 Conservative 339
  8. .. ... ... ...
  9. 103 2005 Others 30
  10. 104 2010 Others 29
  11. 105 2015 Others 80
  12. 106 2017 Others 59
  13. 107 2019 Others 72
  14.  
  15. [60 rows x 3 columns]

你可以把數據看成是每一個可能的 (year, party) 組合的一系列 seats 值。這正是 Bokeh 處理的方式。你需要做一個 (year, party) 元組的列表:

  1. # 得到每種可能的 (year, party) 組合的元組
  2. x = [(str(r[1]['year']), r[1]['party']) for r in df.iterrows()]
  3. # This comes out as [('1922', 'Conservative'), ('1923', 'Conservative'), ... ('2019', 'Others')]

這些將是 x 值。y 值就是席位(seats)。

  1. y = df['seats']

現在你的數據看起來應該像這樣:

  1. x                               y
  2. ('1966', 'Conservative')        253
  3. ('1970', 'Conservative')        330
  4. ('Feb 1974', 'Conservative')    297
  5. ('Oct 1974', 'Conservative')    277
  6. ('1979', 'Conservative')        339
  7.  ...      ...                   ...
  8. ('2005', 'Others')              30
  9. ('2010', 'Others')              29
  10. ('2015', 'Others')              80
  11. ('2017', 'Others')              59
  12. ('2019', 'Others')              72

Bokeh 需要你將數據封裝在它提供的一些對象中,這樣它就能給你提供交互功能。將你的 x 和 y 數據結構封裝在一個 ColumnDataSource 對象中。

  1. from bokeh.models import ColumnDataSource
  2.  
  3. source = ColumnDataSource(data={'x': x, 'y': y})

然后構造一個 Figure 對象,并傳入你用 FactorRange 對象封裝的 x 數據。

  1.     from bokeh.plotting import figure
  2.     from bokeh.models import FactorRange
  3.    
  4.     p = figure(x_range=FactorRange(*x), width=2000, title="Election results")

你需要讓 Bokeh 創建一個顏色表,這是一個特殊的 DataSpec 字典,它根據你給它的顏色映射生成。在這種情況下,顏色表是一個簡單的黨派名稱和一個十六進制值之間的映射。

  1.     from bokeh.transform import factor_cmap
  2.  
  3.     cmap = {
  4.         'Conservative': '#0343df',
  5.         'Labour': '#e50000',
  6.         'Liberal': '#ffff14',
  7.         'Others': '#929591',
  8.     }
  9.     fill_color = factor_cmap('x', palette=list(cmap.values()), factors=list(cmap.keys()), start=1, end=2)

現在你可以創建條形圖了:

  1.     p.vbar(x='x', top='y', width=0.9, source=source, fill_color=fill_color, line_color=fill_color)

Bokeh 圖表上數據的可視化形式被稱為“字形glyphs”,因此你已經創建了一組條形字形。

調整圖表的細節,讓它看起來像你想要的樣子。

  1.     p.y_range.start = 0
  2.     p.x_range.range_padding = 0.1
  3.     p.yaxis.axis_label = 'Seats'
  4.     p.xaxis.major_label_orientation = 1
  5.     p.xgrid.grid_line_color = None

最后,告訴 Bokeh 你現在想看你的繪圖:

  1.    from bokeh.io import show
  2.  
  3.    show(p)

這將繪圖寫入一個 HTML 文件,并在默認的 Web 瀏覽器中打開它。如下結果:

 

Bokeh 中的多條形繪圖(©2019年Anvil

它已經有了一些互動功能,比如盒子縮放。

 

Bokeh 內置的盒子縮放(©2019Anvil

但 Bokeh 的厲害之處在于你可以添加自己的交互性。在下一節中,我們通過在條形圖中添加工具提示來探索這個問題。

給條形圖添加工具提示

要在條形圖上添加工具提示,你只需要創建一個 HoverTool 對象并將其添加到你的繪圖中。

  1.     h = HoverTool(tooltips=[
  2.         ('Seats', '@y'),
  3.         ('(Year, Party)', '(@x)')
  4.     ])
  5.     p.add_tools(h)

參數定義了哪些數據會顯示在工具提示上。變量 @y 和 @x 是指你傳入 ColumnDataSource 的變量。你還可以使用一些其他的值。例如,光標在圖上的位置由 $x 和 $y 給出(與 @x 和 @y 沒有關系)。

下面是結果:

 

選舉圖,現在帶有工具提示(© 2019 Anvil

借助 Bokeh 的 HTML 輸出,將繪圖嵌入到 Web 應用中時,你可以獲得完整的交互體驗。你可以在這里把這個例子復制為 Anvil 應用(注:Anvil 需要注冊才能使用)。

現在,你可以看到付出額外努力在 Bokeh 中將所有數據封裝在 ColumnDataSource 等對象的原因了。作為回報,你可以相對輕松地添加交互性。

回歸簡單:Altair

Bokeh 是四大最流行的繪圖庫之一,本系列將研究它們各自的特別之處

我也在研究幾個因其有趣的方法而脫穎而出的庫。接下來,我將看看 Altair,它的聲明式 API 意味著它可以做出非常復雜的繪圖,而不會讓你頭疼。

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2018-03-09 15:25:47

IOT語義交叉

2010-11-15 16:33:07

Oracle交互性

2018-02-26 16:41:53

定義IOT語義

2023-09-25 10:26:05

DOMCSS

2020-12-20 19:26:20

LVMFedoraLinux

2011-12-07 09:29:56

移動終端網宿科技

2019-07-05 15:42:58

GitHub代碼開發者

2020-01-17 18:40:38

Python游戲代碼

2021-06-09 11:26:37

BokehPython可視化

2018-05-21 14:44:33

LinuxshellPython

2018-10-18 07:50:00

Python編程語言油箱加油

2013-09-09 16:37:48

iOS應用添加內置收費In App Purc

2022-02-25 19:29:07

Vue2esbuild項目

2016-09-21 09:16:55

Qlik

2011-04-22 11:12:42

JavaScript

2017-10-23 10:01:31

軟件交付大數據分析人工智能

2023-08-04 19:26:38

谷歌AI

2015-07-08 16:19:17

iOSUIVisualEff

2023-09-26 19:26:28

OpenAIChatGPTTwitter
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产视频一区二区 | 五月婷婷激情网 | 国产精品久久久久婷婷二区次 | 国产美女自拍视频 | 欧美性jizz18性欧美 | 成人av播放 | 日韩不卡三区 | 亚洲欧美另类在线 | 欧美激情 一区 | 毛片免费观看 | 国产一区二区免费 | 久草精品视频 | 三级免费毛片 | 亚洲人va欧美va人人爽 | av免费网站在线观看 | 国产视频中文字幕 | 欧美精品一区二区三区在线播放 | 亚洲一区成人 | 免费观看黄 | 日本偷偷操 | 欧美激情久久久 | 黄一级| 国产日韩欧美一区 | 欧美日韩一区不卡 | 毛片a级 | 狠狠操狠狠操 | 成人婷婷 | 日韩图区| 中文字幕一区二区三区在线视频 | 久久久久久国产精品久久 | 欧美xxxⅹ性欧美大片 | 亚洲一区在线观看视频 | 日韩免费1区二区电影 | 三级黄片毛片 | 亚洲一区二区久久 | 日本不卡高字幕在线2019 | 黄色一级大片在线免费看产 | 国产农村妇女精品一区 | 国产精品亚洲综合 | 久久伊人一区 | 在线播放亚洲 |