โบเก้ - คู่มือฉบับย่อ

Bokeh เป็นไลบรารีการแสดงข้อมูลสำหรับ Python ซึ่งแตกต่างจาก Matplotlib และ Seaborn พวกเขายังเป็นแพ็คเกจ Python สำหรับการสร้างภาพข้อมูล Bokeh แสดงพล็อตโดยใช้ HTML และ JavaScript ดังนั้นจึงพิสูจน์ได้ว่ามีประโยชน์อย่างยิ่งสำหรับการพัฒนาแดชบอร์ดบนเว็บ

โครงการ Bokeh ได้รับการสนับสนุนโดย NumFocus https://numfocus.org/.NumFocus ยังสนับสนุน PyData ซึ่งเป็นโปรแกรมการศึกษาที่เกี่ยวข้องกับการพัฒนาเครื่องมือสำคัญอื่น ๆ เช่น NumPy, Pandas และอื่น ๆ Bokeh สามารถเชื่อมต่อกับเครื่องมือเหล่านี้ได้อย่างง่ายดายและสร้างแผนโต้ตอบแดชบอร์ดและแอปพลิเคชันข้อมูล

คุณสมบัติ

Bokeh แปลงแหล่งข้อมูลเป็นไฟล์ JSON เป็นหลักซึ่งใช้เป็นอินพุตสำหรับ BokehJS ซึ่งเป็นไลบรารี JavaScript ซึ่งจะเขียนใน TypeScript และแสดงผลการแสดงภาพในเบราว์เซอร์สมัยใหม่

บางส่วนของ important features of Bokeh มีดังนี้ -

ความยืดหยุ่น

โบเก้มีประโยชน์สำหรับความต้องการในการพล็อตทั่วไปตลอดจนกรณีการใช้งานที่กำหนดเองและซับซ้อน

ผลผลิต

Bokeh สามารถโต้ตอบกับเครื่องมือ Pydata ยอดนิยมอื่น ๆ เช่นสมุดบันทึก Pandas และ Jupyter

การโต้ตอบ

นี่เป็นข้อได้เปรียบที่สำคัญของ Bokeh เหนือ Matplotlib และ Seaborn ซึ่งทั้งคู่สร้างพล็อตแบบคงที่ Bokeh สร้างแผนการโต้ตอบที่เปลี่ยนแปลงเมื่อผู้ใช้โต้ตอบกับพวกเขา คุณสามารถให้ผู้ชมของคุณมีตัวเลือกและเครื่องมือมากมายสำหรับการอนุมานและดูข้อมูลจากมุมต่างๆเพื่อให้ผู้ใช้ทำการวิเคราะห์ "จะเกิดอะไรขึ้น"

ทรงพลัง

ด้วยการเพิ่ม JavaScript ที่กำหนดเองทำให้สามารถสร้างการแสดงภาพสำหรับกรณีการใช้งานพิเศษได้

แบ่งปันได้

สามารถฝังพล็อตในเอาต์พุตของ Flask หรือ Djangoเปิดใช้งานเว็บแอปพลิเคชัน นอกจากนี้ยังสามารถแสดงผลในรูปแบบ

ดาวพฤหัสบดี

โอเพ่นซอร์ส

Bokeh เป็นโครงการโอเพ่นซอร์ส เผยแพร่ภายใต้ใบอนุญาต Berkeley Source Distribution (BSD) ซอร์สโค้ดมีอยู่บนhttps://github.com/bokeh/bokeh.

สามารถติดตั้งโบเก้ได้ CPython เวอร์ชัน 2.7 และ 3.5+เฉพาะทั้งที่มีการแจกจ่ายมาตรฐานและการแจกจ่ายอนาคอนดา Bokeh เวอร์ชันปัจจุบันในขณะที่เขียนบทช่วยสอนนี้คือเวอร์ชัน 1.3.4 แพ็คเกจ Bokeh มีการอ้างอิงดังต่อไปนี้ -

  • jinja2> = 2.7
  • จำนวน> = 1.7.1
  • บรรจุภัณฑ์> = 16.8
  • หมอน> = 4.0
  • python-dateutil> = 2.1
  • pyyaml> = 3.10
  • หก> = 1.5.2
  • ทอร์นาโด> = 4.3

โดยทั่วไปแพ็คเกจด้านบนจะถูกติดตั้งโดยอัตโนมัติเมื่อติดตั้ง Bokeh โดยใช้ PIP ตัวจัดการแพ็คเกจในตัวของ Python ดังที่แสดงด้านล่าง -

pip3 install bokeh

หากคุณกำลังใช้การแจกจ่าย Anaconda ให้ใช้ conda package manager ดังต่อไปนี้ -

conda install bokeh

นอกเหนือจากการอ้างอิงข้างต้นคุณอาจต้องการแพ็คเกจเพิ่มเติมเช่นแพนด้า psutil ฯลฯ เพื่อวัตถุประสงค์เฉพาะ

หากต้องการตรวจสอบว่าติดตั้ง Bokeh สำเร็จหรือไม่ให้นำเข้าแพ็คเกจโบเก้ใน Python terminal และตรวจสอบเวอร์ชัน -

>>> import bokeh
>>> bokeh.__version__
'1.3.4'

การสร้างพล็อตเส้นอย่างง่ายระหว่างอาร์เรย์จำนวนสองอาร์เรย์นั้นง่ายมาก เริ่มต้นด้วยการนำเข้าฟังก์ชันต่อไปนี้จากbokeh.plotting โมดูล -

from bokeh.plotting import figure, output_file, show

figure() ฟังก์ชันสร้างตัวเลขใหม่สำหรับการวางแผน

output_file() ฟังก์ชันใช้เพื่อระบุไฟล์ HTML เพื่อจัดเก็บเอาต์พุต

show() ฟังก์ชันแสดงรูปโบเก้ในเบราว์เซอร์ในโน้ตบุ๊ก

จากนั้นตั้งค่าอาร์เรย์ numpy สองอาร์เรย์โดยที่อาร์เรย์ที่สองเป็นค่าไซน์ของอันดับแรก

import numpy as np
import math
x = np.arange(0, math.pi*2, 0.05)
y = np.sin(x)

ในการรับวัตถุรูปโบเก้ให้ระบุชื่อเรื่องและป้ายชื่อแกน x และ y ดังต่อไปนี้ -

p = figure(title = "sine wave example", x_axis_label = 'x', y_axis_label = 'y')

วัตถุ Figure มีวิธี line () ที่เพิ่มสัญลักษณ์เส้นให้กับรูป ต้องการชุดข้อมูลสำหรับแกน x และ y

p.line(x, y, legend = "sine", line_width = 2)

สุดท้ายตั้งค่าไฟล์เอาต์พุตและฟังก์ชัน call show ()

output_file("sine.html")
show(p)

สิ่งนี้จะแสดงเส้นพล็อตใน "sine.html" และจะแสดงในเบราว์เซอร์

รหัสที่สมบูรณ์และผลลัพธ์มีดังนี้

from bokeh.plotting import figure, output_file, show
import numpy as np
import math
x = np.arange(0, math.pi*2, 0.05)
y = np.sin(x)
output_file("sine.html")
p = figure(title = "sine wave example", x_axis_label = 'x', y_axis_label = 'y')
p.line(x, y, legend = "sine", line_width = 2)
show(p)

แสดงผลบนเบราว์เซอร์

การแสดงรูปโบเก้ในสมุดบันทึก Jupyter นั้นคล้ายกับด้านบนมาก การเปลี่ยนแปลงเดียวที่คุณต้องทำคือการนำเข้า output_notebook แทน output_file จากโมดูล bokeh.plotting

from bokeh.plotting import figure, output_notebook, show

ฟังก์ชัน Call to output_notebook () ตั้งค่าเซลล์เอาต์พุตของสมุดบันทึก Jupyter เป็นปลายทางสำหรับฟังก์ชัน show () ดังที่แสดงด้านล่าง -

output_notebook()
show(p)

ป้อนรหัสในเซลล์สมุดบันทึกและเรียกใช้ คลื่นไซน์จะแสดงภายในโน้ตบุ๊ก

แพ็คเกจ Bokeh มีอินเทอร์เฟซสองแบบซึ่งสามารถใช้การวางแผนต่างๆได้

โบเก้รุ่น

โมดูลนี้เป็นอินเทอร์เฟซระดับต่ำ ให้ความยืดหยุ่นอย่างมากแก่ผู้พัฒนาแอปพลิเคชันในการพัฒนาการแสดงภาพ พล็อตโบเก้ส่งผลให้วัตถุมีลักษณะภาพและข้อมูลของฉากซึ่งใช้โดยไลบรารี BokehJS วัตถุระดับต่ำที่ประกอบด้วยกราฟฉากโบเก้เรียกว่าโมเดล

bokeh พล็อต

นี่คืออินเทอร์เฟซระดับสูงกว่าที่มีฟังก์ชันสำหรับการเขียนร่ายมนตร์ภาพ โมดูลนี้ประกอบด้วยคำจำกัดความของคลาส Figure จริงๆแล้วมันเป็นคลาสย่อยของคลาสพล็อตที่กำหนดไว้ในโมดูล bokeh.models

คลาสฟิกเกอร์ช่วยลดความยุ่งยากในการสร้างพล็อต มันมีวิธีการต่างๆในการวาดร่ายมนตร์กราฟิกแบบเวกเตอร์ที่แตกต่างกัน Glyphs เป็นส่วนประกอบสำคัญของพล็อต Bokeh เช่นเส้นวงกลมสี่เหลี่ยมและรูปร่างอื่น ๆ

bokeh.application

คลาสแอปพลิเคชันแพ็คเกจ Bokeh ซึ่งเป็นโรงงานที่มีน้ำหนักเบาสำหรับสร้างเอกสารโบเก้ เอกสารคือคอนเทนเนอร์สำหรับโมเดลโบเก้ที่จะสะท้อนไปยังไลบรารี BokehJS ฝั่งไคลเอ็นต์

bokeh.server

มันมีแอพพลิเคชั่น Bokeh Server Tornadocore ที่ปรับแต่งได้ เซิร์ฟเวอร์ใช้เพื่อแบ่งปันและเผยแพร่แผนการโต้ตอบและแอพให้กับผู้ชมที่คุณเลือก

พล็อตใด ๆ มักประกอบด้วยรูปทรงเรขาคณิตหนึ่งหรือหลายรูปแบบเช่น line, circle, rectangle,เป็นต้นรูปร่างเหล่านี้มีข้อมูลภาพเกี่ยวกับชุดข้อมูลที่เกี่ยวข้อง ในศัพท์โบเก้รูปทรงเรขาคณิตเหล่านี้เรียกว่าจิลฟ์ สร้างโบเก้โดยใช้bokeh.plotting interfaceใช้ชุดเครื่องมือและสไตล์เริ่มต้น อย่างไรก็ตามคุณสามารถปรับแต่งสไตล์โดยใช้เครื่องมือพล็อตที่มีอยู่

ประเภทของพล็อต

พล็อตประเภทต่างๆที่สร้างโดยใช้ร่ายมนตร์มีดังต่อไปนี้ -

พล็อตเส้น

พล็อตประเภทนี้มีประโยชน์สำหรับการแสดงภาพการเคลื่อนไหวของจุดตามแกน x และแกน y ในรูปแบบของเส้น ใช้เพื่อทำการวิเคราะห์อนุกรมเวลา

พล็อตบาร์

โดยทั่วไปจะมีประโยชน์ในการระบุจำนวนคอลัมน์หรือฟิลด์แต่ละหมวดหมู่ในชุดข้อมูลของคุณ

พล็อตแพทช์

พล็อตนี้ระบุพื้นที่ของจุดในเฉดสีที่เฉพาะเจาะจง พล็อตประเภทนี้ใช้เพื่อแยกแยะกลุ่มต่างๆภายในชุดข้อมูลเดียวกัน

พล็อตกระจาย

พล็อตประเภทนี้ใช้เพื่อแสดงภาพความสัมพันธ์ระหว่างสองตัวแปรและเพื่อระบุความแข็งแกร่งของความสัมพันธ์ระหว่างตัวแปรทั้งสอง

รูปแบบที่แตกต่างกันเกิดขึ้นโดยการเรียกวิธีการที่เหมาะสมของคลาส Figure วัตถุรูปได้มาจากตัวสร้างต่อไปนี้ -

from bokeh.plotting import figure
figure(**kwargs)

ออบเจ็กต์ Figure สามารถปรับแต่งได้ด้วยอาร์กิวเมนต์คีย์เวิร์ดต่างๆ

ซีเนียร์ No หัวข้อ ตั้งชื่อเรื่องสำหรับพล็อต
1 x_axis_label ตั้งชื่อแกน x
2 y_axis_label ตั้งชื่อแกน y
3 plot_width กำหนดความกว้างของรูป
4 plot_height กำหนดความสูงของรูป

พล็อตเส้น

line() methodของวัตถุในรูปจะเพิ่มเส้นสัญลักษณ์ให้กับรูปโบเก้ ต้องการพารามิเตอร์ x และ y เป็นอาร์เรย์ข้อมูลเพื่อแสดงความสัมพันธ์เชิงเส้น

from bokeh.plotting import figure, show
fig = figure()
fig.line(x,y)
show(fig)

โค้ดต่อไปนี้แสดงผลพล็อตบรรทัดอย่างง่ายระหว่างสองชุดของค่าในรูปแบบรายการ Python วัตถุ -

from bokeh.plotting import figure, output_file, show
x = [1,2,3,4,5]
y = [2,4,6,8,10]
output_file('line.html')
fig = figure(title = 'Line Plot example', x_axis_label = 'x', y_axis_label = 'y')
fig.line(x,y)
show(fig)

เอาต์พุต

พล็อตบาร์

วัตถุรูปมีสองวิธีที่แตกต่างกันในการสร้างพล็อตแท่ง

hbar ()

แถบจะแสดงในแนวนอนตามความกว้างของพล็อต hbar() method มีพารามิเตอร์ต่อไปนี้ -

ซีเนียร์ No พิกัด y ของจุดศูนย์กลางของแท่งแนวนอน
1 ความสูง ความสูงของแถบแนวตั้ง
2 ขวา พิกัด x ของขอบด้านขวา
3 ซ้าย พิกัด x ของขอบด้านซ้าย

โค้ดต่อไปนี้เป็นตัวอย่างของ horizontal bar ใช้ Bokeh

from bokeh.plotting import figure, output_file, show
fig = figure(plot_width = 400, plot_height = 200)
fig.hbar(y = [2,4,6], height = 1, left = 0, right = [1,2,3], color = "Cyan")
output_file('bar.html')
show(fig)

เอาต์พุต

vbar ()

แถบจะแสดงในแนวตั้งตามความสูงของพล็อต vbar() method มีพารามิเตอร์ดังต่อไปนี้ -

ซีเนียร์ No x พิกัด x ของจุดศูนย์กลางของแท่งแนวตั้ง
1 ความกว้าง ความกว้างของแท่งแนวตั้ง
2 ด้านบน พิกัด y ของขอบด้านบน
3 ด้านล่าง พิกัด y ของขอบด้านล่าง

รหัสต่อไปนี้จะปรากฏขึ้น vertical bar plot -

from bokeh.plotting import figure, output_file, show
fig = figure(plot_width = 200, plot_height = 400)
fig.vbar(x = [1,2,3], width = 0.5, bottom = 0, top = [2,4,6], color = "Cyan")
output_file('bar.html')
show(fig)

เอาต์พุต

พล็อตแพทช์

พล็อตที่แรเงาพื้นที่ว่างด้วยสีเฉพาะเพื่อแสดงพื้นที่หรือกลุ่มที่มีคุณสมบัติคล้ายกันเรียกว่าพล็อตแพทช์ในโบเก้ วัตถุรูปมี patch () และ patches () วิธีการสำหรับวัตถุประสงค์นี้

ปะ()

วิธีนี้จะเพิ่มสัญลักษณ์แพทช์ให้กับร่างที่กำหนด เมธอดมีอาร์กิวเมนต์ดังนี้ -

1 x พิกัด x สำหรับจุดของแพทช์
2 พิกัด y สำหรับจุดของแพตช์

ง่าย patch plot ได้มาจากรหัส Python ต่อไปนี้ -

from bokeh.plotting import figure, output_file, show
p = figure(plot_width = 300, plot_height = 300)
p.patch(x = [1, 3,2,4], y = [2,3,5,7], color = "green")
output_file('patch.html')
show(p)

เอาต์พุต

แพทช์ ()

วิธีนี้ใช้ในการวาดแพทช์หลายเหลี่ยม มันต้องการอาร์กิวเมนต์ต่อไปนี้ -

1 xs พิกัด x สำหรับแพตช์ทั้งหมดที่ระบุเป็น "รายการรายการ"
2 ys พิกัด y สำหรับแพตช์ทั้งหมดที่ระบุเป็น "รายการลิสต์"

ดังตัวอย่างของ patches () method ให้รันโค้ดต่อไปนี้ -

from bokeh.plotting import figure, output_file, show
xs = [[5,3,4], [2,4,3], [2,3,5,4]]
ys = [[6,4,2], [3,6,7], [2,4,7,8]]
fig = figure()
fig.patches(xs, ys, fill_color = ['red', 'blue', 'black'], line_color = 'white')
output_file('patch_plot.html')
show(fig)

เอาต์พุต

เครื่องหมายกระจาย

แผนภาพการกระจายมักใช้เพื่อกำหนดความสัมพันธ์แบบไบ - แปรผันระหว่างสองตัวแปร การโต้ตอบที่ได้รับการปรับปรุงจะถูกเพิ่มเข้ามาโดยใช้ Bokeh Scatter plot ได้มาจากการเรียกเมธอด scatter () ของ Figure object ใช้พารามิเตอร์ต่อไปนี้ -

1 x ค่าหรือชื่อเขตข้อมูลของพิกัดศูนย์ x
2 ค่าหรือชื่อเขตข้อมูลของพิกัดศูนย์ y
3 ขนาด ค่าหรือชื่อฟิลด์ของขนาดในหน่วยหน้าจอ
4 เครื่องหมาย ค่าหรือชื่อเขตข้อมูลของประเภทเครื่องหมาย
5 สี กำหนดสีเติมและสีของเส้น

ค่าคงที่ของประเภทเครื่องหมายต่อไปนี้ถูกกำหนดไว้ในโบเก้: -

  • Asterisk
  • Circle
  • CircleCross
  • CircleX
  • Cross
  • Dash
  • Diamond
  • DiamondCross
  • Hex
  • InvertedTriangle
  • Square
  • SquareCross
  • SquareX
  • Triangle
  • X

ตามโค้ด Python จะสร้าง scatter plot พร้อมเครื่องหมายวงกลม

from bokeh.plotting import figure, output_file, show
fig = figure()
fig.scatter([1, 4, 3, 2, 5], [6, 5, 2, 4, 7], marker = "circle", size = 20, fill_color = "grey")
output_file('scatter.html')
show(fig)

เอาต์พุต

พล็อตพื้นที่เป็นพื้นที่ที่เต็มไปด้วยระหว่างสองชุดที่ใช้ดัชนีร่วมกัน คลาส Figure ของ Bokeh มี 2 วิธีดังนี้ -

วาเรีย ()

ผลลัพธ์ของวิธี varea () คือพื้นที่กำกับแนวตั้งที่มีอาร์เรย์พิกัด x หนึ่งชุดและอาร์เรย์พิกัด y สองชุด y1 และ y2 ซึ่งจะถูกเติมระหว่าง

1 x พิกัด x สำหรับจุดของพื้นที่
2 y1 พิกัด y สำหรับจุดของด้านหนึ่งของพื้นที่
3 y2 พิกัด y สำหรับจุดของอีกด้านหนึ่งของพื้นที่

ตัวอย่าง

from bokeh.plotting import figure, output_file, show
fig = figure()
x = [1, 2, 3, 4, 5]
y1 = [2, 6, 4, 3, 5]
y2 = [1, 4, 2, 2, 3]
fig.varea(x = x,y1 = y1,y2 = y2)
output_file('area.html')
show(fig)

เอาต์พุต

กระต่าย ()

ในทางกลับกันวิธี harea () ต้องการพารามิเตอร์ x1, x2 และ y

1 x1 พิกัด x สำหรับจุดของด้านใดด้านหนึ่งของพื้นที่
2 x2 พิกัด x สำหรับจุดของอีกด้านหนึ่งของพื้นที่
3 พิกัด y สำหรับจุดของพื้นที่

ตัวอย่าง

from bokeh.plotting import figure, output_file, show
fig = figure()
y = [1, 2, 3, 4, 5]
x1 = [2, 6, 4, 3, 5]
x2 = [1, 4, 2, 2, 3]
fig.harea(x1 = x1,x2 = x2,y = y)
output_file('area.html')
show(fig)

เอาต์พุต

วัตถุรูปมีหลายวิธีโดยใช้ร่ายมนตร์ vectorised ที่มีรูปร่างต่างกันเช่น circle, rectangle, polygon, สามารถวาดได้

มีวิธีการวาดภาพต่อไปนี้ circle glyphs -

วงกลม()

circle() วิธีการเพิ่มสัญลักษณ์วงกลมให้กับรูปและต้องการ x และ yพิกัดของศูนย์กลาง นอกจากนี้ยังสามารถกำหนดค่าได้ด้วยความช่วยเหลือของพารามิเตอร์เช่นfill_color, line-color, line_width เป็นต้น

circle_cross ()

Circle_cross () วิธีการเพิ่มสัญลักษณ์วงกลมโดยมีเครื่องหมาย '+' ผ่านตรงกลาง

circle_x ()

Circle_x () วิธีการเพิ่มวงกลมโดยมีเครื่องหมาย 'X' ผ่านตรงกลาง

ตัวอย่าง

ตัวอย่างต่อไปนี้แสดงการใช้ร่ายมนตร์วงกลมต่างๆที่เพิ่มลงในรูปโบเก้ -

from bokeh.plotting import figure, output_file, show
plot = figure(plot_width = 300, plot_height = 300)
plot.circle(x = [1, 2, 3], y = [3,7,5], size = 20, fill_color = 'red')
plot.circle_cross(x = [2,4,6], y = [5,8,9], size = 20, fill_color = 'blue',fill_alpha = 0.2, line_width = 2)
plot.circle_x(x = [5,7,2], y = [2,4,9], size = 20, fill_color = 'green',fill_alpha = 0.6, line_width = 2)
show(plot)

เอาต์พุต

เป็นไปได้ที่จะแสดงผล rectangle, ellipse and polygonsในรูปโบเก้ rect() methodของคลาส Figure เพิ่มรูปสี่เหลี่ยมผืนผ้าตามพิกัด x และ y ของศูนย์กลางความกว้างและความสูง ในทางกลับกันเมธอด square () มีพารามิเตอร์ขนาดเพื่อตัดสินใจมิติ

วิธีการวงรี () และวงรี () จะเพิ่มสัญลักษณ์วงรีและวงรี พวกเขาใช้ลายเซ็นที่คล้ายกับของ rect () ที่มีพารามิเตอร์ x, y, w และ h นอกจากนี้พารามิเตอร์มุมกำหนดการหมุนจากแนวนอน

ตัวอย่าง

รหัสต่อไปนี้แสดงการใช้งานที่แตกต่างกัน shape glyph methods -

from bokeh.plotting import figure, output_file, show
fig = figure(plot_width = 300, plot_height = 300)
fig.rect(x = 10,y = 10,width = 100, height = 50, width_units = 'screen', height_units = 'screen')
fig.square(x = 2,y = 3,size = 80, color = 'red')
fig.ellipse(x = 7,y = 6, width = 30, height = 10, fill_color = None, line_width = 2)
fig.oval(x = 6,y = 6,width = 2, height = 1, angle = -0.4)
show(fig)

เอาต์พุต

arc() methodวาดเส้นโค้งอย่างง่ายตามพิกัด x และ y มุมเริ่มต้นและจุดสิ้นสุดและรัศมี มุมจะได้รับเป็นเรเดียนในขณะที่รัศมีอาจอยู่ในหน่วยหน้าจอหรือหน่วยข้อมูล ลิ่มคือส่วนโค้งที่เติมเต็ม

wedge() methodมีคุณสมบัติเช่นเดียวกับวิธี arc () ทั้งสองวิธีมีคุณสมบัติของทิศทางที่เป็นทางเลือกซึ่งอาจเป็นนาฬิกาหรือแอนติล็อคที่กำหนดทิศทางของการแสดงส่วนโค้ง / ลิ่ม ฟังก์ชัน annular_wedge () แสดงผลพื้นที่ที่เติมเต็มระหว่างส่วนโค้งของรัศมีภายในและภายนอก

ตัวอย่าง

นี่คือตัวอย่างของ arc และ wedge glyphs เพิ่มลงในรูปโบเก้ -

from bokeh.plotting import figure, output_file, show
import math
fig = figure(plot_width = 300, plot_height = 300)
fig.arc(x = 3, y = 3, radius = 50, radius_units = 'screen', start_angle = 0.0, end_angle = math.pi/2)
fig.wedge(x = 3, y = 3, radius = 30, radius_units = 'screen',
start_angle = 0, end_angle = math.pi, direction = 'clock')
fig.annular_wedge(x = 3,y = 3, inner_radius = 100, outer_radius = 75,outer_radius_units = 'screen',
inner_radius_units = 'screen',start_angle = 0.4, end_angle = 4.5,color = "green", alpha = 0.6)
show(fig)

เอาต์พุต

bokeh.plotting API รองรับวิธีการแสดงผลตามเส้นโค้งพิเศษ -

บีเซอร์ ()

วิธีนี้จะเพิ่มเส้นโค้งเบเซียร์ให้กับวัตถุรูป เส้นโค้งเบซิเอร์เป็นเส้นโค้งพาราเมตริกที่ใช้ในคอมพิวเตอร์กราฟิก การใช้งานอื่น ๆ ได้แก่ การออกแบบฟอนต์และแอนิเมชั่นคอมพิวเตอร์การออกแบบส่วนต่อประสานกับผู้ใช้และการปรับทิศทางเคอร์เซอร์ให้ราบรื่น

ในกราฟิกแบบเวกเตอร์เส้นโค้งเบเซียร์ใช้เพื่อสร้างแบบจำลองเส้นโค้งเรียบที่สามารถปรับขนาดได้เรื่อย ๆ "เส้นทาง" คือการรวมกันของเส้นโค้งเบเซียร์ที่เชื่อมโยงกัน

วิธี beizer () มีพารามิเตอร์ต่อไปนี้ซึ่งกำหนดไว้ -

1 x0 พิกัด x ของจุดเริ่มต้น
2 y0 พิกัด y ของจุดเริ่มต้น ..
3 x1 พิกัด x ของจุดสิ้นสุด
4 y1 พิกัด y ของจุดสิ้นสุด
5 cx0 พิกัด x ของจุดควบคุมแรก
6 cy0 พิกัด y ของจุดควบคุมแรก
7 cx1 พิกัด x ของจุดควบคุมที่สอง
8 cy1 พิกัด y ของจุดควบคุมที่สอง

ค่าเริ่มต้นสำหรับพารามิเตอร์ทั้งหมดคือไม่มี

ตัวอย่าง

โค้ดต่อไปนี้สร้างหน้า HTML ที่แสดงเส้นโค้งเบเซียร์และพาราโบลาในพล็อตโบเก้ -

x = 2
y = 4
xp02 = x+0.4
xp01 = x+0.1
xm01 = x-0.1
yp01 = y+0.2
ym01 = y-0.2
fig = figure(plot_width = 300, plot_height = 300)
fig.bezier(x0 = x, y0 = y, x1 = xp02, y1 = y, cx0 = xp01, cy0 = yp01,
cx1 = xm01, cy1 = ym01, line_color = "red", line_width = 2)

เอาต์พุต

กำลังสอง ()

วิธีนี้จะเพิ่มไฟล์ parabola glyphเป็นรูปโบเก้ ฟังก์ชันนี้มีพารามิเตอร์เช่นเดียวกับ beizer () ยกเว้นcx0 และ cx1.

ตัวอย่าง

รหัสที่ระบุด้านล่างสร้างเส้นโค้งกำลังสอง

x = 2
y = 4
xp02 = x + 0.3
xp01 = x + 0.2
xm01 = x - 0.4
yp01 = y + 0.1
ym01 = y - 0.2
x = x,
y = y,
xp02 = x + 0.4,
xp01 = x + 0.1,
yp01 = y + 0.2,
fig.quadratic(x0 = x, y0 = y, x1 = x + 0.4, y1 = y + 0.01, cx = x + 0.1,
cy = y + 0.2, line_color = "blue", line_width = 3)

เอาต์พุต

ช่วงตัวเลขของแกนข้อมูลของพล็อตจะถูกกำหนดโดยอัตโนมัติโดย Bokeh โดยคำนึงถึงชุดข้อมูลที่อยู่ระหว่างกระบวนการ อย่างไรก็ตามบางครั้งคุณอาจต้องการกำหนดช่วงของค่าบนแกน x และ y อย่างชัดเจน ซึ่งทำได้โดยการกำหนดคุณสมบัติ x_range และ y_range ให้กับฟังก์ชัน figure ()

ช่วงเหล่านี้กำหนดโดยใช้ฟังก์ชัน range1d ()

ตัวอย่าง

xrange = range1d(0,10)

ในการใช้วัตถุช่วงนี้เป็นคุณสมบัติ x_range ให้ใช้รหัสด้านล่าง -

fig = figure(x,y,x_range = xrange)

ในบทนี้เราจะพูดถึงประเภทต่างๆของแกน

ซีเนียร์ No แกน คำอธิบาย
1 แกนหมวดหมู่ พล็อตโบเก้แสดงข้อมูลตัวเลขตามทั้งแกน x และ y ในการใช้ข้อมูลหมวดหมู่ตามแกนใดแกนหนึ่งเราจำเป็นต้องระบุ FactorRange เพื่อระบุมิติข้อมูลเชิงหมวดหมู่สำหรับหนึ่งในนั้น
2 แกนมาตราส่วนล็อก หากมีความสัมพันธ์ของกฎหมายกำลังระหว่างชุดข้อมูล x และ y เป็นที่พึงปรารถนาที่จะใช้มาตราส่วนบันทึกบนทั้งสองแกน
3 แกนคู่ อาจจำเป็นต้องแสดงหลายแกนที่แสดงช่วงที่แตกต่างกันในรูปพล็อตเดียว วัตถุรูปสามารถกำหนดค่าได้โดยการกำหนดextra_x_range และ extra_y_range คุณสมบัติ

แกนหมวดหมู่

ในตัวอย่างที่ผ่านมาพล็อตโบเก้จะแสดงข้อมูลตัวเลขตามแกน x และ y ในการใช้ข้อมูลหมวดหมู่ตามแกนใดแกนหนึ่งเราจำเป็นต้องระบุ FactorRange เพื่อระบุมิติข้อมูลเชิงหมวดหมู่สำหรับหนึ่งในนั้น ตัวอย่างเช่นในการใช้สตริงในรายการที่กำหนดสำหรับแกน x -

langs = ['C', 'C++', 'Java', 'Python', 'PHP']
fig = figure(x_range = langs, plot_width = 300, plot_height = 300)

ตัวอย่าง

ด้วยตัวอย่างต่อไปนี้พล็อตแท่งธรรมดาจะแสดงจำนวนนักเรียนที่ลงทะเบียนเรียนในหลักสูตรต่างๆที่เปิดสอน

from bokeh.plotting import figure, output_file, show
langs = ['C', 'C++', 'Java', 'Python', 'PHP']
students = [23,17,35,29,12]
fig = figure(x_range = langs, plot_width = 300, plot_height = 300)
fig.vbar(x = langs, top = students, width = 0.5)
show(fig)

เอาต์พุต

หากต้องการแสดงแต่ละแถบด้วยสีที่ต่างกันให้ตั้งค่าคุณสมบัติสีของฟังก์ชัน vbar () เป็นรายการค่าสี

cols = ['red','green','orange','navy', 'cyan']
fig.vbar(x = langs, top = students, color = cols,width=0.5)

เอาต์พุต

ในการแสดงผลแถบแบบเรียงซ้อนในแนวตั้ง (หรือแนวนอน) โดยใช้ฟังก์ชัน vbar_stack () หรือ hbar_stack () ให้ตั้งค่าคุณสมบัติ stackers เป็นรายการของเขตข้อมูลเพื่อเรียงซ้อนกันอย่างต่อเนื่องและคุณสมบัติต้นทางให้กับวัตถุ dict ที่มีค่าที่สอดคล้องกับแต่ละฟิลด์

ในตัวอย่างต่อไปนี้การขายคือพจนานุกรมที่แสดงตัวเลขยอดขายของผลิตภัณฑ์สามรายการในสามเดือน

from bokeh.plotting import figure, output_file, show
products = ['computer','mobile','printer']
months = ['Jan','Feb','Mar']
sales = {'products':products,
   'Jan':[10,40,5],
   'Feb':[8,45,10],
   'Mar':[25,60,22]}
cols = ['red','green','blue']#,'navy', 'cyan']
fig = figure(x_range = products, plot_width = 300, plot_height = 300)
fig.vbar_stack(months, x = 'products', source = sales, color = cols,width = 0.5)
show(fig)

เอาต์พุต

พล็อตแท่งที่จัดกลุ่มได้จากการระบุการกระจัดภาพสำหรับแท่งด้วยความช่วยเหลือของฟังก์ชัน dodge () ใน bokeh.transform โมดูล.

dodge() functionแนะนำการชดเชยสัมพัทธ์สำหรับแต่ละพล็อตแท่งเพื่อให้ได้ภาพของกลุ่ม ในตัวอย่างต่อไปนี้vbar() glyph คั่นด้วยค่าชดเชย 0.25 สำหรับแต่ละกลุ่มแท่งสำหรับเดือนหนึ่ง ๆ

from bokeh.plotting import figure, output_file, show
from bokeh.transform import dodge
products = ['computer','mobile','printer']
months = ['Jan','Feb','Mar']
sales = {'products':products,
   'Jan':[10,40,5],
   'Feb':[8,45,10],
   'Mar':[25,60,22]}
fig = figure(x_range = products, plot_width = 300, plot_height = 300)
fig.vbar(x = dodge('products', -0.25, range = fig.x_range), top = 'Jan',
   width = 0.2,source = sales, color = "red")
fig.vbar(x = dodge('products', 0.0, range = fig.x_range), top = 'Feb',
   width = 0.2, source = sales,color = "green")
fig.vbar(x = dodge('products', 0.25, range = fig.x_range), top = 'Mar',
   width = 0.2,source = sales,color = "blue")
show(fig)

เอาต์พุต

แกนมาตราส่วนล็อก

เมื่อค่าบนแกนใดแกนหนึ่งของพล็อตเพิ่มขึ้นแบบทวีคูณพร้อมกับค่าที่เพิ่มขึ้นเชิงเส้นของอีกค่าหนึ่งมักจำเป็นต้องมีการแสดงข้อมูลบนแกนเดิมบนมาตราส่วนบันทึก ตัวอย่างเช่นหากมีความสัมพันธ์ของกฎหมายกำลังระหว่างชุดข้อมูล x และ y ขอแนะนำให้ใช้มาตราส่วนบันทึกบนทั้งสองแกน

ฟังก์ชันรูป () ของ Bokeh.plotting API ยอมรับ x_axis_type และ y_axis_type เป็นอาร์กิวเมนต์ซึ่งอาจระบุเป็นแกนบันทึกโดยส่ง "log" สำหรับค่าของพารามิเตอร์เหล่านี้

รูปแรกแสดงพล็อตระหว่าง x ถึง 10x ในสเกลเชิงเส้น ในรูปที่สอง y_axis_type ถูกตั้งค่าเป็น 'log'

from bokeh.plotting import figure, output_file, show
x = [0.1, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0]
y = [10**i for i in x]
fig = figure(title = 'Linear scale example',plot_width = 400, plot_height = 400)
fig.line(x, y, line_width = 2)
show(fig)

เอาต์พุต

ตอนนี้เปลี่ยนรูป () ฟังก์ชั่นเพื่อกำหนดค่า y_axis_type = 'log'

fig = figure(title = 'Linear scale example',plot_width = 400, plot_height = 400, y_axis_type = "log")

เอาต์พุต

แกนคู่

ในบางสถานการณ์อาจจำเป็นต้องแสดงหลายแกนที่แสดงช่วงที่แตกต่างกันในรูปพล็อตเดียว วัตถุรูปสามารถกำหนดค่าได้โดยการกำหนดextra_x_range และ extra_y_rangeคุณสมบัติ. ในขณะที่เพิ่มสัญลักษณ์ใหม่ให้กับรูปจะใช้ช่วงที่ตั้งชื่อเหล่านี้

We try to display a sine curve and a straight line in same plot. Both glyphs have y axes with different ranges. The x and y data series for sine curve and line are obtained by the following −

from numpy import pi, arange, sin, linspace
x = arange(-2*pi, 2*pi, 0.1)
y = sin(x)
y2 = linspace(0, 100, len(y))

Here, plot between x and y represents sine relation and plot between x and y2 is a straight line. The Figure object is defined with explicit y_range and a line glyph representing sine curve is added as follows −

fig = figure(title = 'Twin Axis Example', y_range = (-1.1, 1.1))
fig.line(x, y, color = "red")

We need an extra y range. It is defined as −

fig.extra_y_ranges = {"y2": Range1d(start = 0, end = 100)}

To add additional y axis on right side, use add_layout() method. Add a new line glyph representing x and y2 to the figure.

fig.add_layout(LinearAxis(y_range_name = "y2"), 'right')
fig.line(x, y2, color = "blue", y_range_name = "y2")

This will result in a plot with twin y axes. Complete code and the output is as follows −

from numpy import pi, arange, sin, linspace
x = arange(-2*pi, 2*pi, 0.1)
y = sin(x)
y2 = linspace(0, 100, len(y))
from bokeh.plotting import output_file, figure, show
from bokeh.models import LinearAxis, Range1d
fig = figure(title='Twin Axis Example', y_range = (-1.1, 1.1))
fig.line(x, y, color = "red")
fig.extra_y_ranges = {"y2": Range1d(start = 0, end = 100)}
fig.add_layout(LinearAxis(y_range_name = "y2"), 'right')
fig.line(x, y2, color = "blue", y_range_name = "y2")
show(fig)

Output

Annotations are pieces of explanatory text added to the diagram. Bokeh plot can be annotated by way of specifying plot title, labels for x and y axes as well as inserting text labels anywhere in the plot area.

Plot title as well as x and y axis labels can be provided in the Figure constructor itself.

fig = figure(title, x_axis_label, y_axis_label)

In the following plot, these properties are set as shown below −

from bokeh.plotting import figure, output_file, show
import numpy as np
import math
x = np.arange(0, math.pi*2, 0.05)
y = np.sin(x)
fig = figure(title = "sine wave example", x_axis_label = 'angle', y_axis_label = 'sin')
fig.line(x, y,line_width = 2)
show(p)

Output

The title’s text and axis labels can also be specified by assigning appropriate string values to corresponding properties of figure object.

fig.title.text = "sine wave example"
fig.xaxis.axis_label = 'angle'
fig.yaxis.axis_label = 'sin'

It is also possible to specify location, alignment, font and color of title.

fig.title.align = "right"
fig.title.text_color = "orange"
fig.title.text_font_size = "25px"
fig.title.background_fill_color = "blue"

Adding legends to the plot figure is very easy. We have to use legend property of any glyph method.

Below we have three glyph curves in the plot with three different legends −

from bokeh.plotting import figure, output_file, show
import numpy as np
import math
x = np.arange(0, math.pi*2, 0.05)
fig = figure()
fig.line(x, np.sin(x),line_width = 2, line_color = 'navy', legend = 'sine')
fig.circle(x,np.cos(x), line_width = 2, line_color = 'orange', legend = 'cosine')
fig.square(x,-np.sin(x),line_width = 2, line_color = 'grey', legend = '-sine')
show(fig)

Output

In all the examples above, the data to be plotted has been provided in the form of Python lists or numpy arrays. It is also possible to provide the data source in the form of pandas DataFrame object.

DataFrame is a two-dimensional data structure. Columns in the dataframe can be of different data types. The Pandas library has functions to create dataframe from various sources such as CSV file, Excel worksheet, SQL table, etc.

For the purpose of following example, we are using a CSV file consisting of two columns representing a number x and 10x. The test.csv file is as below −

x,pow
0.0,1.0
0.5263157894736842,3.3598182862837818
1.0526315789473684,11.28837891684689
1.5789473684210527,37.926901907322495
2.1052631578947367,127.42749857031335
2.631578947368421,428.1332398719391
3.1578947368421053,1438.449888287663
3.6842105263157894,4832.930238571752
4.2105263157894735,16237.76739188721
4.7368421052631575,54555.947811685146

We shall read this file in a dataframe object using read_csv() function in pandas.

import pandas as pd
df = pd.read_csv('test.csv')
print (df)

The dataframe appears as below −

x        pow
0 0.000000 1.000000
1 0.526316 3.359818
2 1.052632 11.288379
3 1.578947 37.926902
4 2.105263 127.427499
5 2.631579 428.133240
6 3.157895 1438.449888
7 3.684211 4832.930239
8 4.210526 16237.767392
9 4.736842 54555.947812

The ‘x’ and ‘pow’ columns are used as data series for line glyph in bokeh plot figure.

from bokeh.plotting import figure, output_file, show
p = figure()
x = df['x']
y = df['pow']
p.line(x,y,line_width = 2)
p.circle(x, y,size = 20)
show(p)

Output

Most of the plotting methods in Bokeh API are able to receive data source parameters through ColumnDatasource object. It makes sharing data between plots and ‘DataTables’.

A ColumnDatasource can be considered as a mapping between column name and list of data. A Python dict object with one or more string keys and lists or numpy arrays as values is passed to ColumnDataSource constructor.

Example

Below is the example

from bokeh.models import ColumnDataSource
data = {'x':[1, 4, 3, 2, 5],
   'y':[6, 5, 2, 4, 7]}
cds = ColumnDataSource(data = data)

This object is then used as value of source property in a glyph method. Following code generates a scatter plot using ColumnDataSource.

from bokeh.plotting import figure, output_file, show
from bokeh.models import ColumnDataSource
data = {'x':[1, 4, 3, 2, 5],
   'y':[6, 5, 2, 4, 7]}
cds = ColumnDataSource(data = data)
fig = figure()
fig.scatter(x = 'x', y = 'y',source = cds, marker = "circle", size = 20, fill_color = "grey")
show(fig)

Output

Instead of assigning a Python dictionary to ColumnDataSource, we can use a Pandas DataFrame for it.

Let us use ‘test.csv’ (used earlier in this section) to obtain a DataFrame and use it for getting ColumnDataSource and rendering line plot.

from bokeh.plotting import figure, output_file, show
import pandas as pd
from bokeh.models import ColumnDataSource
df = pd.read_csv('test.csv')
cds = ColumnDataSource(df)
fig = figure(y_axis_type = 'log')
fig.line(x = 'x', y = 'pow',source = cds, line_color = "grey")
show(fig)

Output

Often, you may want to obtain a plot pertaining to a part of data that satisfies certain conditions instead of the entire dataset. Object of the CDSView class defined in bokeh.models module returns a subset of ColumnDatasource under consideration by applying one or more filters over it.

IndexFilter is the simplest type of filter. You have to specify indices of only those rows from the dataset that you want to use while plotting the figure.

Following example demonstrates use of IndexFilter to set up a CDSView. The resultant figure shows a line glyph between x and y data series of the ColumnDataSource. A view object is obtained by applying index filter over it. The view is used to plot circle glyph as a result of IndexFilter.

Example

from bokeh.models import ColumnDataSource, CDSView, IndexFilter
from bokeh.plotting import figure, output_file, show
source = ColumnDataSource(data = dict(x = list(range(1,11)), y = list(range(2,22,2))))
view = CDSView(source=source, filters = [IndexFilter([0, 2, 4,6])])
fig = figure(title = 'Line Plot example', x_axis_label = 'x', y_axis_label = 'y')
fig.circle(x = "x", y = "y", size = 10, source = source, view = view, legend = 'filtered')
fig.line(source.data['x'],source.data['y'], legend = 'unfiltered')
show(fig)

Output

To choose only those rows from the data source, that satisfy a certain Boolean condition, apply a BooleanFilter.

A typical Bokeh installation consists of a number of sample data sets in sampledata directory. For following example, we use unemployment1948 dataset provided in the form of unemployment1948.csv. It stores year wise percentage of unemployment in USA since 1948. We want to generate a plot only for year 1980 onwards. For that purpose, a CDSView object is obtained by applying BooleanFilter over the given data source.

from bokeh.models import ColumnDataSource, CDSView, BooleanFilter
from bokeh.plotting import figure, show
from bokeh.sampledata.unemployment1948 import data
source = ColumnDataSource(data)
booleans = [True if int(year) >= 1980 else False for year in
source.data['Year']]
print (booleans)
view1 = CDSView(source = source, filters=[BooleanFilter(booleans)])
p = figure(title = "Unemployment data", x_range = (1980,2020), x_axis_label = 'Year', y_axis_label='Percentage')
p.line(x = 'Year', y = 'Annual', source = source, view = view1, color = 'red', line_width = 2)
show(p)

Output

To add more flexibility in applying filter, Bokeh provides a CustomJSFilter class with the help of which the data source can be filtered with a user defined JavaScript function.

The example given below uses the same USA unemployment data. Defining a CustomJSFilter to plot unemployment figures of year 1980 and after.

from bokeh.models import ColumnDataSource, CDSView, CustomJSFilter
from bokeh.plotting import figure, show
from bokeh.sampledata.unemployment1948 import data
source = ColumnDataSource(data)
custom_filter = CustomJSFilter(code = '''
   var indices = [];

   for (var i = 0; i < source.get_length(); i++){
      if (parseInt(source.data['Year'][i]) > = 1980){
         indices.push(true);
      } else {
         indices.push(false);
      }
   }
   return indices;
''')
view1 = CDSView(source = source, filters = [custom_filter])
p = figure(title = "Unemployment data", x_range = (1980,2020), x_axis_label = 'Year', y_axis_label = 'Percentage')
p.line(x = 'Year', y = 'Annual', source = source, view = view1, color = 'red', line_width = 2)
show(p)

Bokeh visualizations can be suitably arranged in different layout options. These layouts as well as sizing modes result in plots and widgets resizing automatically as per the size of browser window. For consistent appearance, all items in a layout must have same sizing mode. The widgets (buttons, menus, etc.) are kept in a separate widget box and not in plot figure.

First type of layout is Column layout which displays plot figures vertically. The column() function is defined in bokeh.layouts module and takes following signature −

from bokeh.layouts import column
col = column(children, sizing_mode)

children − List of plots and/or widgets.

sizing_mode − determines how items in the layout resize. Possible values are "fixed", "stretch_both", "scale_width", "scale_height", "scale_both". Default is “fixed”.

Following code produces two Bokeh figures and places them in a column layout so that they are displayed vertically. Line glyphs representing sine and cos relationship between x and y data series is displayed in Each figure.

from bokeh.plotting import figure, output_file, show
from bokeh.layouts import column
import numpy as np
import math
x = np.arange(0, math.pi*2, 0.05)
y1 = np.sin(x)
y2 = np.cos(x)
fig1 = figure(plot_width = 200, plot_height = 200)
fig1.line(x, y1,line_width = 2, line_color = 'blue')
fig2 = figure(plot_width = 200, plot_height = 200)
fig2.line(x, y2,line_width = 2, line_color = 'red')
c = column(children = [fig1, fig2], sizing_mode = 'stretch_both')
show(c)

Output

Similarly, Row layout arranges plots horizontally, for which row() function as defined in bokeh.layouts module is used. As you would think, it also takes two arguments (similar to column() function) – children and sizing_mode.

The sine and cos curves as shown vertically in above diagram are now displayed horizontally in row layout with following code

from bokeh.plotting import figure, output_file, show
from bokeh.layouts import row
import numpy as np
import math
x = np.arange(0, math.pi*2, 0.05)
y1 = np.sin(x)
y2 = np.cos(x)
fig1 = figure(plot_width = 200, plot_height = 200)
fig1.line(x, y1,line_width = 2, line_color = 'blue')
fig2 = figure(plot_width = 200, plot_height = 200)
fig2.line(x, y2,line_width = 2, line_color = 'red')
r = row(children = [fig1, fig2], sizing_mode = 'stretch_both')
show(r)

Output

The Bokeh package also has grid layout. It holds multiple plot figures (as well as widgets) in a two dimensional grid of rows and columns. The gridplot() function in bokeh.layouts module returns a grid and a single unified toolbar which may be positioned with the help of toolbar_location property.

This is unlike row or column layout where each plot shows its own toolbar. The grid() function too uses children and sizing_mode parameters where children is a list of lists. Ensure that each sublist is of same dimensions.

In the following code, four different relationships between x and y data series are plotted in a grid of two rows and two columns.

from bokeh.plotting import figure, output_file, show
from bokeh.layouts import gridplot
import math
x = list(range(1,11))

y1 = x
y2 =[11-i for i in x]
y3 = [i*i for i in x]
y4 = [math.log10(i) for i in x]

fig1 = figure(plot_width = 200, plot_height = 200)
fig1.line(x, y1,line_width = 2, line_color = 'blue')
fig2 = figure(plot_width = 200, plot_height = 200)
fig2.circle(x, y2,size = 10, color = 'green')
fig3 = figure(plot_width = 200, plot_height = 200)
fig3.circle(x,y3, size = 10, color = 'grey')
fig4 = figure(plot_width = 200, plot_height = 200, y_axis_type = 'log')
fig4.line(x,y4, line_width = 2, line_color = 'red')
grid = gridplot(children = [[fig1, fig2], [fig3,fig4]], sizing_mode = 'stretch_both')
show(grid)

Output

When a Bokeh plot is rendered, normally a tool bar appears on the right side of the figure. It contains a default set of tools. First of all, the position of toolbar can be configured by toolbar_location property in figure() function. This property can take one of the following values −

  • "above"
  • "below"
  • "left"
  • "right"
  • "None"

For example, following statement will cause toolbar to be displayed below the plot −

Fig = figure(toolbar_location = "below")

This toolbar can be configured according to the requirement by adding required from various tools defined in bokeh.models module. For example −

Fig.add_tools(WheelZoomTool())

The tools can be classified under following categories −

  • Pan/Drag Tools
  • Click/Tap Tools
  • Scroll/Pinch Tools
Tool Description Icon

BoxSelectTool

Name : 'box_select'

allows the user to define a rectangular selection region by left-dragging a mouse

LassoSelectTool

name: 'lasso_select

allows the user to define an arbitrary region for selection by left-dragging a mouse

PanTool

name: 'pan', 'xpan', 'ypan',

allows the user to pan the plot by left-dragging a mouse

TapTool

name: 'tap

allows the user to select at single points by clicking a left mouse button

WheelZoomTool

name: 'wheel_zoom', 'xwheel_zoom', 'ywheel_zoom'

zoom the plot in and out, centered on the current mouse location.

WheelPanTool

name: 'xwheel_pan', 'ywheel_pan'

translate the plot window along the specified dimension without changing the window’s aspect ratio.

ResetTool

name: 'reset'

restores the plot ranges to their original values.

SaveTool

name: 'save'

allows the user to save a PNG image of the plot.

ZoomInTool

name: 'zoom_in', 'xzoom_in', 'yzoom_in'

The zoom-in tool will increase the zoom of the plot in x, y or both coordinates

ZoomOutTool

name: 'zoom_out', 'xzoom_out', 'yzoom_out'

The zoom-out tool will decrease the zoom of the plot in x, y or both coordinates

CrosshairTool

name: 'crosshair'

draws a crosshair annotation over the plot, centered on the current mouse position.

The default appearance of a Bokeh plot can be customised by setting various properties to desired value. These properties are mainly of three types −

Line properties

Following table lists various properties related to line glyph.

1 line_color color is used to stroke lines with
2 line_width This is used in units of pixels as line stroke width
3 line_alpha Between 0 (transparent) and 1 (opaque) this acts as a floating point
4 line_join how to join together the path segments. Defined values are: 'miter' (miter_join), 'round' (round_join), 'bevel' (bevel_join)
5 line_cap how to terminate the path segments. Defined values are: 'butt' (butt_cap), 'round' (round_cap), 'square' (square_cap)
6 line_dash BThis is used for a line style. Defined values are: 'solid', 'dashed', 'dotted', 'dotdash', 'dashdot'
7 line_dash_offset The distance into the line_dash in pixels that the pattern should start from

Fill properties

Various fill properties are listed below −

1 fill_color This is used to fill paths with
2 fill_alpha Between 0 (transparent) and 1 (opaque), this acts as a floating point

Text properties

There are many text related properties as listed in the following table −

1 text_font font name, e.g., 'times', 'helvetica'
2 text_font_size font size in px, em, or pt, e.g., '12pt', '1.5em'
3 text_font_style font style to use 'normal' 'italic' 'bold'
4 text_color This is used to render text with
5 text_alpha Between 0 (transparent) and 1 (opaque), this is a floating point
6 text_align horizontal anchor point for text - 'left', 'right', 'center'
7 text_baseline vertical anchor point for text 'top', 'middle', 'bottom', 'alphabetic', 'hanging'

ร่ายมนตร์ต่างๆในพล็อตสามารถระบุได้โดยคุณสมบัติตำนานจะปรากฏเป็นเลเบลตามค่าเริ่มต้นที่ตำแหน่งบนขวาของพื้นที่พล็อต ตำนานนี้สามารถปรับแต่งได้ตามคุณลักษณะต่อไปนี้ -

1 legend.label_text_font เปลี่ยนแบบอักษรฉลากเริ่มต้นเป็นชื่อแบบอักษรที่ระบุ
2 legend.label_text_font_size ขนาดตัวอักษรเป็นจุด
3 ตำนาน ตั้งป้ายตามตำแหน่งที่ระบุ
4 legend.title ตั้งชื่อสำหรับป้ายกำกับตำนาน
5 legend.orientation ตั้งค่าเป็นแนวนอน (ค่าเริ่มต้น) หรือแนวตั้ง
6 legend.clicking_policy ระบุสิ่งที่ควรเกิดขึ้นเมื่อคลิกคำอธิบายแผนภูมิซ่อน: ซ่อนสัญลักษณ์ที่สอดคล้องกับปิดเสียงตำนาน: ปิดเสียงสัญลักษณ์ที่เกี่ยวข้องกับคำอธิบายแผนภูมิ>

ตัวอย่าง

ตัวอย่างโค้ดสำหรับการปรับแต่งตำนานมีดังนี้ -

from bokeh.plotting import figure, output_file, show
import math
x2 = list(range(1,11))
y4 = [math.pow(i,2) for i in x2]
y2 = [math.log10(pow(10,i)) for i in x2]
fig = figure(y_axis_type = 'log')
fig.circle(x2, y2,size = 5, color = 'blue', legend = 'blue circle')
fig.line(x2,y4, line_width = 2, line_color = 'red', legend = 'red line')
fig.legend.location = 'top_left'
fig.legend.title = 'Legend Title'
fig.legend.title_text_font = 'Arial'
fig.legend.title_text_font_size = '20pt'
show(fig)

เอาต์พุต

โมดูล bokeh.models.widgets มีคำจำกัดความของวัตถุ GUI ที่คล้ายกับองค์ประกอบในรูปแบบ HTML เช่นปุ่มแถบเลื่อนช่องทำเครื่องหมายปุ่มตัวเลือก ฯลฯ ส่วนควบคุมเหล่านี้มีส่วนติดต่อแบบโต้ตอบกับพล็อต การเรียกใช้การประมวลผลเช่นการแก้ไขข้อมูลพล็อตการเปลี่ยนพารามิเตอร์พล็อต ฯลฯ สามารถดำเนินการได้โดยฟังก์ชัน JavaScript แบบกำหนดเองที่ดำเนินการกับเหตุการณ์ที่เกี่ยวข้อง

Bokeh ช่วยให้สามารถกำหนดฟังก์ชันการโทรกลับได้ด้วยสองวิธี -

  • ใช้ CustomJS callback เพื่อให้การโต้ตอบทำงานในเอกสาร HTML แบบสแตนด์อโลน

  • ใช้ Bokeh server และตั้งค่าตัวจัดการเหตุการณ์

ในส่วนนี้เราจะดูวิธีเพิ่มวิดเจ็ต Bokeh และกำหนดการเรียกกลับ JavaScript

ปุ่ม

วิดเจ็ตนี้เป็นปุ่มที่คลิกได้โดยทั่วไปใช้เพื่อเรียกใช้ตัวจัดการการโทรกลับที่ผู้ใช้กำหนด ตัวสร้างใช้พารามิเตอร์ต่อไปนี้ -

Button(label, icon, callback)

พารามิเตอร์ label คือสตริงที่ใช้เป็นคำอธิบายภาพของปุ่มและการเรียกกลับคือฟังก์ชัน JavaScript ที่กำหนดเองที่จะเรียกใช้เมื่อคลิก

ในตัวอย่างต่อไปนี้วิดเจ็ตพล็อตและปุ่มจะแสดงในเค้าโครงคอลัมน์ พล็อตเองแสดงสัญลักษณ์เส้นระหว่างชุดข้อมูล x และ y

มีการกำหนดฟังก์ชัน JavaScript ที่กำหนดเองชื่อ 'callback' โดยใช้ CutomJS() function. ได้รับการอ้างอิงถึงออบเจ็กต์ที่เรียกใช้การเรียกกลับ (ในกรณีนี้คือปุ่ม) ในตัวแปรรูปแบบ cb_obj

ฟังก์ชันนี้จะแก้ไขข้อมูล ColumnDataSource ต้นทางและในที่สุดก็จะส่งการอัปเดตนี้ในข้อมูลต้นทาง

from bokeh.layouts import column
from bokeh.models import CustomJS, ColumnDataSource
from bokeh.plotting import Figure, output_file, show
from bokeh.models.widgets import Button

x = [x*0.05 for x in range(0, 200)]
y = x

source = ColumnDataSource(data=dict(x=x, y=y))
plot = Figure(plot_width=400, plot_height=400)
plot.line('x', 'y', source=source, line_width=3, line_alpha=0.6)

callback = CustomJS(args=dict(source=source), code="""
   var data = source.data;
   x = data['x']
   y = data['y']
   for (i = 0; i < x.length; i++) {
      y[i] = Math.pow(x[i], 4)
   }
   source.change.emit();
""")

btn = Button(label="click here", callback=callback, name="1")

layout = column(btn , plot)
show(layout)

เอาต์พุต (เริ่มต้น)

คลิกที่ปุ่มด้านบนของพล็อตและดูรูปพล็อตที่อัปเดตซึ่งมีลักษณะดังนี้ -

เอาต์พุต (หลังจากคลิก)

ตัวเลื่อน

ด้วยความช่วยเหลือของตัวควบคุมแถบเลื่อนคุณสามารถเลือกหมายเลขระหว่างคุณสมบัติเริ่มต้นและสิ้นสุดที่กำหนดให้

Slider(start, end, step, value)

ในตัวอย่างต่อไปนี้เราลงทะเบียนฟังก์ชันการโทรกลับในเหตุการณ์ on_change ของตัวเลื่อน ค่าตัวเลขทันทีของ Slider พร้อมใช้งานสำหรับตัวจัดการในรูปแบบของ cb_obj.value ซึ่งใช้เพื่อแก้ไขข้อมูล ColumnDatasource รูปพล็อตจะอัปเดตอย่างต่อเนื่องเมื่อคุณเลื่อนตำแหน่ง

from bokeh.layouts import column
from bokeh.models import CustomJS, ColumnDataSource
from bokeh.plotting import Figure, output_file, show
from bokeh.models.widgets import Slider

x = [x*0.05 for x in range(0, 200)]
y = x

source = ColumnDataSource(data=dict(x=x, y=y))
plot = Figure(plot_width=400, plot_height=400)
plot.line('x', 'y', source=source, line_width=3, line_alpha=0.6)

handler = CustomJS(args=dict(source=source), code="""
   var data = source.data;
   var f = cb_obj.value
   var x = data['x']
   var y = data['y']
   for (var i = 0; i < x.length; i++) {
      y[i] = Math.pow(x[i], f)
   }
   source.change.emit();
""")

slider = Slider(start=0.0, end=5, value=1, step=.25, title="Slider Value")

slider.js_on_change('value', handler)
layout = column(slider, plot)
show(layout)

เอาต์พุต

RadioGroup

วิดเจ็ตนี้นำเสนอคอลเลกชันของปุ่มสลับที่ใช้ร่วมกันซึ่งแสดงปุ่มวงกลมทางด้านซ้ายของคำอธิบายภาพ

RadioGroup(labels, active)

โดยที่ป้ายกำกับคือรายการคำอธิบายภาพและใช้งานอยู่คือดัชนีของตัวเลือกที่เลือก

เลือก

วิดเจ็ตนี้เป็นรายการแบบเลื่อนลงแบบง่ายของรายการสตริงซึ่งหนึ่งในนั้นสามารถเลือกได้ สตริงที่เลือกจะปรากฏที่หน้าต่างด้านบนและเป็นพารามิเตอร์ค่า

Select(options, value)

รายการองค์ประกอบสตริงในดรอปดาวน์จะได้รับในรูปแบบของอ็อบเจ็กต์รายการตัวเลือก

ต่อไปนี้เป็นตัวอย่างรวมของปุ่มตัวเลือกและวิดเจ็ตที่เลือกซึ่งทั้งสองมีความสัมพันธ์ที่แตกต่างกันสามแบบระหว่างชุดข้อมูล x และ y RadioGroup และ Select widgets ได้รับการลงทะเบียนกับตัวจัดการที่เกี่ยวข้องโดยใช้เมธอด on_change ()

from bokeh.layouts import column
from bokeh.models import CustomJS, ColumnDataSource
from bokeh.plotting import Figure, output_file, show
from bokeh.models.widgets import RadioGroup, Select

x = [x*0.05 for x in range(0, 200)]
y = x

source = ColumnDataSource(data=dict(x=x, y=y))

plot = Figure(plot_width=400, plot_height=400)
plot.line('x', 'y', source=source, line_width=3, line_alpha=0.6)

radiohandler = CustomJS(args=dict(source=source), code="""
   var data = source.data;
   console.log('Tap event occurred at x-position: ' + cb_obj.active);
   //plot.title.text=cb_obj.value;
   x = data['x']
   y = data['y']
   if (cb_obj.active==0){
      for (i = 0; i < x.length; i++) {
         y[i] = x[i];
      }
   }
   if (cb_obj.active==1){
      for (i = 0; i < x.length; i++) {
         y[i] = Math.pow(x[i], 2)
      }
   }
   if (cb_obj.active==2){
      for (i = 0; i < x.length; i++) {
         y[i] = Math.pow(x[i], 4)
      }
   }
   source.change.emit();
""")

selecthandler = CustomJS(args=dict(source=source), code="""
   var data = source.data;
   console.log('Tap event occurred at x-position: ' + cb_obj.value);
   //plot.title.text=cb_obj.value;
   x = data['x']
   y = data['y']
   if (cb_obj.value=="line"){
      for (i = 0; i < x.length; i++) {
         y[i] = x[i];
      }
   }
   if (cb_obj.value=="SquareCurve"){
      for (i = 0; i < x.length; i++) {
         y[i] = Math.pow(x[i], 2)
      }
   }
   if (cb_obj.value=="CubeCurve"){
      for (i = 0; i < x.length; i++) {
         y[i] = Math.pow(x[i], 4)
      }
   }
   source.change.emit();
""")

radio = RadioGroup(
   labels=["line", "SqureCurve", "CubeCurve"], active=0)
radio.js_on_change('active', radiohandler)
select = Select(title="Select:", value='line', options=["line", "SquareCurve", "CubeCurve"])
select.js_on_change('value', selecthandler)

layout = column(radio, select, plot)
show(layout)

เอาต์พุต

วิดเจ็ตแท็บ

เช่นเดียวกับในเบราว์เซอร์แต่ละแท็บสามารถแสดงหน้าเว็บที่แตกต่างกันวิดเจ็ต Tab คือโมเดลโบเก้ที่ให้มุมมองที่แตกต่างกันสำหรับแต่ละรูป ในตัวอย่างต่อไปนี้พล็อตร่างสองเส้นของเส้นโค้งไซน์และโคไซน์จะแสดงผลในสองแท็บที่แตกต่างกัน -

from bokeh.plotting import figure, output_file, show
from bokeh.models import Panel, Tabs
import numpy as np
import math
x=np.arange(0, math.pi*2, 0.05)
fig1=figure(plot_width=300, plot_height=300)

fig1.line(x, np.sin(x),line_width=2, line_color='navy')

tab1 = Panel(child=fig1, title="sine")
fig2=figure(plot_width=300, plot_height=300)
fig2.line(x,np.cos(x), line_width=2, line_color='orange')
tab2 = Panel(child=fig2, title="cos")

tabs = Tabs(tabs=[ tab1, tab2 ])

show(tabs)

เอาต์พุต

สถาปัตยกรรมโบเก้มีการออกแบบแยกซึ่งวัตถุเช่นพล็อตและร่ายมนตร์ถูกสร้างขึ้นโดยใช้ Python และแปลงเป็น JSON เพื่อใช้โดย BokehJS client library.

อย่างไรก็ตามเป็นไปได้ที่จะเก็บวัตถุใน python และในเบราว์เซอร์ให้ตรงกันด้วยความช่วยเหลือของ Bokeh Server. เปิดใช้งานการตอบสนองต่อเหตุการณ์อินเทอร์เฟซผู้ใช้ (UI) ที่สร้างขึ้นในเบราว์เซอร์ด้วย python เต็มประสิทธิภาพ นอกจากนี้ยังช่วยผลักดันการอัปเดตฝั่งเซิร์ฟเวอร์ไปยังวิดเจ็ตหรือพล็อตในเบราว์เซอร์โดยอัตโนมัติ

เซิร์ฟเวอร์ Bokeh ใช้รหัสแอปพลิเคชันที่เขียนด้วย Python เพื่อสร้างเอกสาร Bokeh ทุกการเชื่อมต่อใหม่จากเบราว์เซอร์ไคลเอนต์ส่งผลให้เซิร์ฟเวอร์ Bokeh สร้างเอกสารใหม่เฉพาะสำหรับเซสชันนั้น

ขั้นแรกเราต้องพัฒนารหัสแอปพลิเคชันเพื่อให้บริการกับเบราว์เซอร์ไคลเอนต์ รหัสต่อไปนี้แสดงสัญลักษณ์เส้นคลื่นไซน์ นอกจากพล็อตแล้วยังมีการแสดงการควบคุมแถบเลื่อนเพื่อควบคุมความถี่ของคลื่นไซน์ ฟังก์ชันการโทรกลับupdate_data() การปรับปรุง ColumnDataSource ข้อมูลที่รับค่าทันทีของแถบเลื่อนเป็นความถี่ปัจจุบัน

import numpy as np
from bokeh.io import curdoc
from bokeh.layouts import row, column
from bokeh.models import ColumnDataSource
from bokeh.models.widgets import Slider, TextInput
from bokeh.plotting import figure
N = 200
x = np.linspace(0, 4*np.pi, N)
y = np.sin(x)
source = ColumnDataSource(data = dict(x = x, y = y))
plot = figure(plot_height = 400, plot_width = 400, title = "sine wave")
plot.line('x', 'y', source = source, line_width = 3, line_alpha = 0.6)
freq = Slider(title = "frequency", value = 1.0, start = 0.1, end = 5.1, step = 0.1)
def update_data(attrname, old, new):
   a = 1
   b = 0
   w = 0
   k = freq.value
   x = np.linspace(0, 4*np.pi, N)
   y = a*np.sin(k*x + w) + b
   source.data = dict(x = x, y = y)
freq.on_change('value', update_data)
curdoc().add_root(row(freq, plot, width = 500))
curdoc().title = "Sliders"

จากนั้นเริ่มเซิร์ฟเวอร์ Bokeh โดยทำตามบรรทัดคำสั่ง -

Bokeh serve –show sliders.py

เซิร์ฟเวอร์ Bokeh เริ่มทำงานและให้บริการแอปพลิเคชันที่ localhost: 5006 / sliders บันทึกคอนโซลแสดงการแสดงผลต่อไปนี้ -

C:\Users\User>bokeh serve --show scripts\sliders.py
2019-09-29 00:21:35,855 Starting Bokeh server version 1.3.4 (running on Tornado 6.0.3)
2019-09-29 00:21:35,875 Bokeh app running at: http://localhost:5006/sliders
2019-09-29 00:21:35,875 Starting Bokeh server with process id: 3776
2019-09-29 00:21:37,330 200 GET /sliders (::1) 699.99ms
2019-09-29 00:21:38,033 101 GET /sliders/ws?bokeh-protocol-version=1.0&bokeh-session-id=VDxLKOzI5Ppl9kDvEMRzZgDVyqnXzvDWsAO21bRCKRZZ (::1) 4.00ms
2019-09-29 00:21:38,045 WebSocket connection opened
2019-09-29 00:21:38,049 ServerConnection created

เปิดเบราว์เซอร์ที่คุณชื่นชอบและป้อนที่อยู่ด้านบน แผนภาพคลื่นไซน์จะแสดงดังนี้ -

คุณสามารถลองและเปลี่ยนความถี่เป็น 2 ได้โดยเลื่อนแถบเลื่อน

แอ็พพลิเคชัน Bokeh มีคำสั่งย่อยจำนวนมากที่จะดำเนินการจากบรรทัดคำสั่ง ตารางต่อไปนี้แสดงคำสั่งย่อย -

1 Html สร้างไฟล์ HTML สำหรับแอปพลิเคชันตั้งแต่หนึ่งรายการขึ้นไป
2 ข้อมูล พิมพ์ข้อมูลการกำหนดค่าเซิร์ฟเวอร์ Bokeh
3 json สร้างไฟล์ JSON สำหรับแอปพลิเคชันตั้งแต่หนึ่งรายการขึ้นไป
4 png สร้างไฟล์ PNG สำหรับแอปพลิเคชันตั้งแต่หนึ่งแอปพลิเคชันขึ้นไป
5 ข้อมูลตัวอย่าง ดาวน์โหลดชุดข้อมูลตัวอย่างโบเก้
6 ความลับ สร้างคีย์ลับ Bokeh เพื่อใช้กับเซิร์ฟเวอร์ Bokeh
7 ให้บริการ เรียกใช้เซิร์ฟเวอร์ Bokeh ที่โฮสต์หนึ่งแอปพลิเคชันขึ้นไป
8 คงที่ แสดงเนื้อหาแบบคงที่ (JavaScript, CSS, รูปภาพ, ฟอนต์ ฯลฯ ) ที่ใช้โดยไลบรารี BokeJS
9 svg สร้างไฟล์ SVG สำหรับแอปพลิเคชันตั้งแต่หนึ่งแอปพลิเคชันขึ้นไป

คำสั่งต่อไปนี้สร้างไฟล์ HTML สำหรับสคริปต์ Python ที่มีรูปโบเก้

C:\python37>bokeh html -o app.html app.py

การเพิ่มตัวเลือกการแสดงจะเปิดไฟล์ HTML ในเบราว์เซอร์โดยอัตโนมัติ ในทำนองเดียวกันสคริปต์ Python จะถูกแปลงเป็นไฟล์ PNG, SVG, JSON ด้วยคำสั่งย่อยที่เกี่ยวข้อง

ในการแสดงข้อมูลของเซิร์ฟเวอร์ Bokeh ให้ใช้คำสั่งย่อย info ดังนี้ -

C:\python37>bokeh info
Python version : 3.7.4 (tags/v3.7.4:e09359112e, Jul 8 2019, 20:34:20) [MSC v.1916 64 bit (AMD64)]
IPython version : (not installed)
Tornado version : 6.0.3
Bokeh version : 1.3.4
BokehJS static path : c:\python37\lib\site-packages\bokeh\server\static
node.js version : (not installed)
npm version : (not installed)

เพื่อทดลองใช้พล็อตประเภทต่างๆเว็บไซต์ Bokeh https://bokeh.pydata.orgทำให้มีชุดข้อมูลตัวอย่าง สามารถดาวน์โหลดลงในเครื่องโลคัลได้โดยใช้คำสั่งย่อย sampledata

C:\python37>bokeh info

ดาวน์โหลดชุดข้อมูลต่อไปนี้ในโฟลเดอร์ C: \ Users \ User \ .bokeh \ data -

AAPL.csv                                     airports.csv
airports.json                                CGM.csv
FB.csv                                       gapminder_fertility.csv
gapminder_life_expectancy.csv                gapminder_population.csv
gapminder_regions.csv                        GOOG.csv
haarcascade_frontalface_default.xml          IBM.csv
movies.db                                    MSFT.csv
routes.csv                                   unemployment09.csv
us_cities.json                               US_Counties.csv
world_cities.csv
WPP2012_SA_DB03_POPULATION_QUINQUENNIAL.csv

คำสั่งย่อย secret สร้างคีย์ลับเพื่อใช้ร่วมกับคำสั่งย่อย serve ที่มีตัวแปรสภาวะแวดล้อม SECRET_KEY

นอกเหนือจากคำสั่งย่อยที่อธิบายไว้ข้างต้นแล้ว Bokeh plot ยังสามารถส่งออกไปยังรูปแบบไฟล์ PNG และ SVG โดยใช้ฟังก์ชัน export () เพื่อจุดประสงค์นั้นการติดตั้ง Python ในเครื่องควรมีไลบรารีอ้างอิงต่อไปนี้

PhantomJS

PhantomJS เป็น JavaScript API ที่เปิดใช้การนำทางอัตโนมัติภาพหน้าจอพฤติกรรมของผู้ใช้และการยืนยัน ใช้เพื่อเรียกใช้การทดสอบหน่วยบนเบราว์เซอร์ PhantomJS ใช้ WebKit ซึ่งให้สภาพแวดล้อมการท่องเว็บที่คล้ายกันสำหรับเบราว์เซอร์ที่แตกต่างกันและให้การสนับสนุนที่รวดเร็วและเป็นระบบสำหรับมาตรฐานเว็บต่างๆ: การจัดการ DOM, ตัวเลือก CSS, JSON, Canvas และ SVG กล่าวอีกนัยหนึ่ง PhantomJS เป็นเว็บเบราว์เซอร์ที่ไม่มีอินเทอร์เฟซผู้ใช้แบบกราฟิก

หมอน

Pillow ซึ่งเป็น Python Imaging Library (ก่อนหน้านี้รู้จักกันในชื่อ PIL) เป็นไลบรารีฟรีสำหรับภาษาโปรแกรม Python ที่ให้การสนับสนุนสำหรับการเปิดการจัดการและการบันทึกไฟล์รูปภาพหลายรูปแบบ (รวมถึง PPM, PNG, JPEG, GIF, TIFF และ BMP) คุณลักษณะบางอย่าง ได้แก่ การปรับแต่งต่อพิกเซลการจัดการการกำบังและความโปร่งใสการกรองภาพการปรับปรุงภาพ ฯลฯ

ฟังก์ชัน export_png () สร้างรูปภาพ PNG ในรูปแบบ RGBA จากเค้าโครง ฟังก์ชันนี้ใช้เบราว์เซอร์ไร้หัวของ Webkit เพื่อแสดงเค้าโครงในหน่วยความจำแล้วจับภาพหน้าจอ รูปภาพที่สร้างขึ้นจะมีขนาดเดียวกันกับเลย์เอาต์ต้นทาง ตรวจสอบให้แน่ใจว่า Plot.background_fill_color และ Plot.border_fill_color เป็นคุณสมบัติของ None

from bokeh.io import export_png
export_png(plot, filename = "file.png")

เป็นไปได้ว่าเอาต์พุตพล็อต HTML5 Canvas ที่มีองค์ประกอบ SVG ซึ่งสามารถแก้ไขได้โดยใช้โปรแกรมเช่น Adobe Illustrator นอกจากนี้วัตถุ SVG ยังสามารถแปลงเป็น PDF ได้ ที่นี่ canvas2svg ไลบรารี JavaScript ถูกใช้เพื่อล้อเลียนองค์ประกอบ Canvas ปกติและวิธีการของมันด้วยองค์ประกอบ SVG เช่นเดียวกับ PNG ในการสร้าง SVG ที่มีพื้นหลังโปร่งใสคุณสมบัติ Plot.background_fill_color และ Plot.border_fill_color ควรเป็นไม่มี

แบ็กเอนด์ SVG จะเปิดใช้งานครั้งแรกโดยตั้งค่าแอตทริบิวต์ Plot.output_backend เป็น "svg"

plot.output_backend = "svg"

สำหรับการส่งออกแบบไม่มีหัวโบเก้มีฟังก์ชันยูทิลิตี้คือ export_svgs () ฟังก์ชันนี้จะดาวน์โหลดพล็อตที่เปิดใช้ SVG ทั้งหมดภายในเลย์เอาต์เป็นไฟล์ SVG ที่แตกต่างกัน

from bokeh.io import export_svgs
plot.output_backend = "svg"
export_svgs(plot, filename = "plot.svg")

พล็อตและข้อมูลในรูปแบบของเอกสารแบบสแตนด์อโลนรวมถึงแอปพลิเคชัน Bokeh สามารถฝังอยู่ในเอกสาร HTML ได้

เอกสารเดี่ยวคือพล็อตโบเก้หรือเอกสารที่ไม่ได้รับการสนับสนุนจากเซิร์ฟเวอร์ Bokeh การโต้ตอบในพล็อตดังกล่าวล้วนอยู่ในรูปแบบของ JS ที่กำหนดเองเท่านั้นไม่ใช่การเรียกกลับ Pure Python

นอกจากนี้ยังสามารถฝังพล็อตโบเก้และเอกสารที่สนับสนุนโดยเซิร์ฟเวอร์ Bokeh ได้ เอกสารดังกล่าวมีการเรียกกลับของ Python ที่รันบนเซิร์ฟเวอร์

ในกรณีของเอกสารแบบสแตนด์อโลนโค้ด HTML ดิบที่แสดงพล็อตโบเก้จะได้มาจากฟังก์ชัน file_html ()

from bokeh.plotting import figure
from bokeh.resources import CDN
from bokeh.embed import file_html
fig = figure()
fig.line([1,2,3,4,5], [3,4,5,2,3])
string = file_html(plot, CDN, "my plot")

ค่าส่งกลับของฟังก์ชัน file_html () อาจถูกบันทึกเป็นไฟล์ HTML หรืออาจใช้เพื่อแสดงผลผ่านเส้นทาง URL ในแอป Flask

ในกรณีของเอกสารแบบสแตนด์อโลนการแทนค่า JSON สามารถรับได้โดยฟังก์ชัน json_item ()

from bokeh.plotting import figure
from bokeh.embed import file_html
import json
fig = figure()
fig.line([1,2,3,4,5], [3,4,5,2,3])
item_text = json.dumps(json_item(fig, "myplot"))

เอาต์พุตนี้สามารถใช้โดยฟังก์ชัน Bokeh.embed.embed_item บนเว็บเพจ -

item = JSON.parse(item_text);
Bokeh.embed.embed_item(item);

นอกจากนี้ยังอาจฝังแอปพลิเคชัน Bokeh บน Bokeh Server เพื่อให้มีการสร้างเซสชันและเอกสารใหม่ในการโหลดทุกหน้าเพื่อให้มีการโหลดเซสชันที่มีอยู่เฉพาะ ซึ่งสามารถทำได้ด้วยฟังก์ชัน server_document () ยอมรับ URL ไปยังแอ็พพลิเคชันเซิร์ฟเวอร์ Bokeh และส่งคืนสคริปต์ที่จะฝังเซสชันใหม่จากเซิร์ฟเวอร์นั้นทุกครั้งที่เรียกใช้สคริปต์

server_document() functionยอมรับพารามิเตอร์ URL หากตั้งค่าเป็น "ค่าเริ่มต้น" URL เริ่มต้น http: // localhost: 5006 / จะถูกใช้

from bokeh.embed import server_document
script = server_document("http://localhost:5006/sliders")

ฟังก์ชัน server_document () ส่งคืนแท็กสคริปต์ดังนี้ -

<script
   src="http://localhost:5006/sliders/autoload.js?bokeh-autoload-element=1000&bokeh-app-path=/sliders&bokeh-absolute-url=https://localhost:5006/sliders"
   id="1000">
</script>

โบเก้ทำงานร่วมกับไลบรารีอื่น ๆ ได้เป็นอย่างดีช่วยให้คุณใช้เครื่องมือที่เหมาะสมที่สุดสำหรับแต่ละงาน ความจริงที่ว่า Bokeh สร้าง JavaScript ทำให้สามารถรวมเอาต์พุต Bokeh กับไลบรารี JavaScript ที่หลากหลายเช่น PhosphorJS

Datashader (https://github.com/bokeh/datashader)เป็นไลบรารีอื่นที่สามารถขยายเอาต์พุต Bokeh ได้ เป็นไลบรารี Python ที่แสดงชุดข้อมูลขนาดใหญ่ล่วงหน้าเป็นภาพแรสเตอร์ขนาดใหญ่ ความสามารถนี้เอาชนะข้อ จำกัด ของเบราว์เซอร์เมื่อมีข้อมูลขนาดใหญ่มาก Datashader มีเครื่องมือในการสร้างพล็อต Bokeh แบบโต้ตอบซึ่งจะแสดงภาพเหล่านี้แบบไดนามิกเมื่อซูมและแพนใน Bokeh ทำให้สามารถทำงานกับชุดข้อมูลขนาดใหญ่ได้ตามอำเภอใจในเว็บเบราว์เซอร์

ไลบรารีอีกแห่งคือ Holoviews ( (http://holoviews.org/)ซึ่งมีอินเทอร์เฟซที่เปิดเผยอย่างรัดกุมสำหรับการสร้างพล็อต Bokeh โดยเฉพาะในสมุดบันทึก Jupyter ซึ่งช่วยอำนวยความสะดวกในการสร้างต้นแบบอย่างรวดเร็วของตัวเลขสำหรับการวิเคราะห์ข้อมูล

เมื่อต้องใช้ชุดข้อมูลขนาดใหญ่ในการสร้างภาพด้วยความช่วยเหลือของ Bokeh การโต้ตอบอาจช้ามาก เพื่อจุดประสงค์นั้นเราสามารถเปิดใช้งานการสนับสนุน Web Graphics Library (WebGL)

WebGL เป็น JavaScript API ที่แสดงเนื้อหาในเบราว์เซอร์โดยใช้ GPU (หน่วยประมวลผลกราฟิก) ปลั๊กอินมาตรฐานนี้มีให้บริการในเบราว์เซอร์สมัยใหม่ทั้งหมด

ในการเปิดใช้งาน WebGL สิ่งที่คุณต้องทำคือตั้งค่าคุณสมบัติ output_backend ของวัตถุ Bokeh Figure เป็น 'webgl'

fig = figure(output_backend="webgl")

ในตัวอย่างต่อไปนี้เราวาด a scatter glyph ประกอบด้วย 10,000 คะแนนด้วยความช่วยเหลือของการสนับสนุน WebGL

import numpy as np
from bokeh.plotting import figure, show, output_file
N = 10000
x = np.random.normal(0, np.pi, N)
y = np.sin(x) + np.random.normal(0, 0.2, N)
output_file("scatterWebGL.html")
p = figure(output_backend="webgl")
p.scatter(x, y, alpha=0.1)
show(p)

เอาต์พุต

ไลบรารี Bokeh Python และไลบรารีสำหรับภาษาอื่น ๆ เช่น R, Scala และ Julia ส่วนใหญ่โต้ตอบกับ BokehJS ในระดับสูง โปรแกรมเมอร์ Python ไม่ต้องกังวลเกี่ยวกับ JavaScript หรือการพัฒนาเว็บ อย่างไรก็ตามเราสามารถใช้ BokehJS API เพื่อพัฒนา JavaScript โดยใช้ BokehJS ได้โดยตรง

วัตถุ BokehJS เช่นร่ายมนตร์และวิดเจ็ตถูกสร้างขึ้นมากหรือน้อยเช่นเดียวกับใน Bokeh Python API โดยทั่วไป Python ClassName จะมีให้ในรูปแบบBokeh.ClassNameจาก JavaScript ตัวอย่างเช่นวัตถุ Range1d ที่ได้รับใน Python

xrange = Range1d(start=-0.5, end=20.5)

ได้รับเทียบเท่ากับ BokehJS เป็น -

var xrange = new Bokeh.Range1d({ start: -0.5, end: 20.5 });

ตามโค้ด JavaScript เมื่อฝังอยู่ในไฟล์ HTML จะแสดงพล็อตบรรทัดอย่างง่ายในเบราว์เซอร์

ขั้นแรกให้รวมไลบรารี BokehJS ทั้งหมดไว้ใน <head> .. </head> secion ของหน้าเว็บดังต่อไปนี้

<head>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-widgets-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-tables-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-gl-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-api-1.3.4.min.js"></script>
<script type="text/javascript" src="https://cdn.pydata.org/bokeh/release/bokeh-api-1.3.4.min.js"></script>
</head>

ในส่วนเนื้อหาต่อจากส่วนย่อยของ JavaScript จะสร้างส่วนต่างๆของ Bokeh Plot

<script>
// create some data and a ColumnDataSource
var x = Bokeh.LinAlg.linspace(-0.5, 20.5, 10);
var y = x.map(function (v) { return v * 0.5 + 3.0; });
var source = new Bokeh.ColumnDataSource({ data: { x: x, y: y } });
// make the plot
var plot = new Bokeh.Plot({
   title: "BokehJS Plot",
   plot_width: 400,
   plot_height: 400
});

// add axes to the plot
var xaxis = new Bokeh.LinearAxis({ axis_line_color: null });
var yaxis = new Bokeh.LinearAxis({ axis_line_color: null });
plot.add_layout(xaxis, "below");
plot.add_layout(yaxis, "left");

// add a Line glyph
var line = new Bokeh.Line({
   x: { field: "x" },
   y: { field: "y" },
   line_color: "#666699",
   line_width: 2
});
plot.add_glyph(line, source);

Bokeh.Plotting.show(plot);
</script>

บันทึกโค้ดด้านบนเป็นหน้าเว็บและเปิดในเบราว์เซอร์ที่คุณเลือก