欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django上使用數(shù)據(jù)可視化利器Bokeh解析

 更新時間:2019年07月31日 10:54:15   作者:柴柴土  
這篇文章主要介紹了Django上使用數(shù)據(jù)可視化利器Bokeh解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下

前言

最近在實驗室做的一個項目中,需要把大量的數(shù)據(jù)在 web 端進(jìn)行可視化,需要繪制各類圖表。數(shù)據(jù)都是以 csv 文件的形式保存在服務(wù)器中。本來是想使用 D3.js 這個數(shù)據(jù)可視化前端庫來畫圖,但是需要編寫大量的 js 代碼。后來發(fā)現(xiàn)了 Bokeh 這個框架,只需要在后端編寫及少量的 Python 代碼生成對應(yīng)的 html 與 js,再傳送到前端讓瀏覽器解析,大大的減少了工作量。

1. 波形圖

這里繪制一個包含了數(shù)千個數(shù)據(jù)點(diǎn)的信號波形圖,繪制方法和 Matlab 如出一轍。學(xué)習(xí)成本為零。

import pandas as pd
from bokeh.plotting import figure
from bokeh.io import output_file, show

csv_file = 'points.csv'
data = pd.read_csv(csv_file)
TOOLS = 'hover,crosshair,pan,wheel_zoom,box_zoom,reset,save,box_select'
picture = figure(width=1000, height=400, tools=TOOLS)
picture.line(data['order'], data['value'], color='blue', alpha=0.5)
output_file('waveform.html', title='waveform')
show(picture)

points.csv 中包含了 2048 個點(diǎn)。上面這段腳本是直接生成了一個 html 文件,show(picture)語句打開了這個 html 文件。效果如下:

右側(cè)的工具欄是通過TOOLS = 'hover,crosshair,pan,wheel_zoom,box_zoom,reset,save,box_select'設(shè)置的。包含了常見的一些功能,包括縮放,保存,重置等等。由于簡書的 markdown 不支持直接插入 div 塊和 js 腳本,所以只能截取一個圖放在這里,不能體驗到右側(cè)的工具欄的使用感受。

2. 集成到 Django 中

上面的例子是直接生成了一個 html 文件,但在正常的使用中,只應(yīng)該生成對應(yīng)的 div 和 js 就行了。
在 Django 的 view.py 中,定義一個 view。

def waveform(request):
  csv_file = 'your file'
  data = pd.read_csv(csv_file) 
  TOOLS = "hover,crosshair,pan,wheel_zoom,box_zoom,reset,save,box_select"
  picture = figure(width=1200, height=400, tools=TOOLS) 
  picture.line(data['order'], data['value'], color='blue', alpha=0.5)
  script, div = components(picture, CDN)
  return render(request, 'waveform.html', {'script': script, 'div': div})

這樣就把對應(yīng)的 template 的 waveform.html 中:

{% load static %}
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Experiment with Bokeh</title>
  <link href="{% static 'bokeh-0.12.4.min.css' %}" rel="stylesheet" type="text/css">
  <link href="{% static 'bokeh-widgets-0.12.4.min.css' %}" rel="stylesheet" type="text/css">
  <script src="{% static 'bokeh-0.12.4.min.js' %}"></script>
  <script src="{% static 'bokeh-widgets-0.12.4.min.js' %}"></script>
  {{ script |safe }}
</head>
<body>
{{ div |safe }}
</body>
</html>

這里有一個不太好的地方,把 script 放到了 head 里面。

然而要是放在底部。就不能正確畫出圖了。(求大神解答)

3. 時頻圖

在經(jīng)過短時傅里葉變換輸出的結(jié)果,可以用 image 來顯示時頻分布圖。與 Matlab 畫出來的也是如出一轍。

import numpy as np
import pandas as pd
from bokeh.io import output_file, show
from bokeh.plotting import figure
data = pd.read_csv('tf_stft.csv')
value = np.array(data['value'])
d = np.reshape(value, (338, 124))
d = np.transpose(d)
TOOLS = "hover,crosshair,pan,wheel_zoom,box_zoom,reset,save,box_select"
p = figure(x_range=(0, 62), y_range=(0, 169), tools=TOOLS)
p.image(image=[d], x=0, y=0, dw=62, dh=169, palette="Viridis256")
output_file("image.html", title="image.py example")
show(p)

結(jié)果如下:

如果是使用 D3.js 來繪制這個圖形的話,就比較費(fèi)勁了。

4. 小結(jié)

Bokeh 這個框架,比起 D3.js,它的可視化選項相對較少。因此,目前來看 Bokeh 無法挑戰(zhàn) D3.js 的霸主地位。而且 Bokeh 過于依賴 python 的數(shù)值計算庫,并非一個純前端的框架,使得它的使用范圍也小于 D3.js。

而在純 python 的數(shù)值計算領(lǐng)域,也已經(jīng)有 matplotlib 這種提供了與 Matlab 一模一樣的接口的數(shù)據(jù)可視化庫,Bokeh 的適用場景也并不多。
但是,它非常適合嵌入 Flask 或者 Django 的程序中,非常好用,速度也很快。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python圖片處理之圖片采樣處理詳解

    Python圖片處理之圖片采樣處理詳解

    這篇文章將詳細(xì)為大家講解圖像采樣處理,包括原理知識、代碼實現(xiàn)和局部馬賽克處理。文中的示例代碼講解詳細(xì),感興趣的可以跟隨小編一起動手試一試
    2022-02-02
  • python實現(xiàn)掃描ip地址的小程序

    python實現(xiàn)掃描ip地址的小程序

    本文通過實例代碼給大家介紹了python實現(xiàn)掃描ip地址的小程序,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2019-04-04
  • Python分析學(xué)校四六級過關(guān)情況

    Python分析學(xué)校四六級過關(guān)情況

    這篇文章主要為大家詳細(xì)介紹了利用Python分析學(xué)校四六級過關(guān)情況,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 說說如何遍歷Python列表的方法示例

    說說如何遍歷Python列表的方法示例

    這篇文章主要介紹了如何遍歷Python列表的方法示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • python @classmethod 的使用場合詳解

    python @classmethod 的使用場合詳解

    這篇文章主要介紹了python @classmethod 的使用場合詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • python構(gòu)造IP報文實例

    python構(gòu)造IP報文實例

    這篇文章主要介紹了python構(gòu)造IP報文實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05
  • PyCharm最新激活碼(2020/10/27全網(wǎng)最新)

    PyCharm最新激活碼(2020/10/27全網(wǎng)最新)

    Pycharm最新激活碼全網(wǎng)最新(2020/10/27更新),適用Intellij idea 2020.2.x,WebStorm 2020.2.x,Pycharm 2020.2.x
    2020-10-10
  • Django中Model的使用方法教程

    Django中Model的使用方法教程

    最近學(xué)習(xí)了一下Django文檔的model部分,通過學(xué)習(xí)的內(nèi)容整理了這篇文章,下面這篇文章主要給大家介紹了關(guān)于Django中Model的使用方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • 零基礎(chǔ)寫python爬蟲之使用urllib2組件抓取網(wǎng)頁內(nèi)容

    零基礎(chǔ)寫python爬蟲之使用urllib2組件抓取網(wǎng)頁內(nèi)容

    文章詳細(xì)介紹了在python2.5環(huán)境下,如何使用urllib2這個python自帶的組件進(jìn)行抓取指定網(wǎng)頁內(nèi)容的,整個過程記錄的非常的詳細(xì),也很簡單,有需要的朋友可以參考下,寫出自己的python爬蟲
    2014-11-11
  • Python繪制動態(tài)的521玫瑰花

    Python繪制動態(tài)的521玫瑰花

    敲了這么多年代碼,每年都得畫一些心啊花啊什么的,所以現(xiàn)在常規(guī)的已經(jīng)有些倦怠了,至少也得來個三維圖形才看著比較合理,所以本文就來繪制一個動態(tài)的玫瑰花吧
    2023-05-05

最新評論