- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试实现类似 Bokeh 图的效果 movies例如,从 postgresql 数据库中获取数据。我几乎完成了所有事情,除了一件事,比如我的情节没有被渲染。
在我的场景中,当我尝试渲染绘图时,它成功地从数据库中获取记录并在日志中显示数据,但它没有渲染我的绘图。找到下面的截图:
此外,如果您注意到,它会显示已选择 2 个事件,并且它也没有渲染 x 轴和 y 轴标签及其范围。
这是我的代码:
from os.path import dirname, join
import sys
import numpy as np
import pandas.io.sql as psql
import psycopg2
from datetime import datetime
from bokeh.plotting import figure
from bokeh.layouts import layout, widgetbox
from bokeh.models import ColumnDataSource, HoverTool, Div
from bokeh.models.widgets import Slider, Select, TextInput, DatePicker, DateRangeSlider
from bokeh.io import curdoc
try:
#Create a database session
conn = psycopg2.connect(database='movies', user='postgres', password='postgres')
#Create a client cursor to execute commands
cursor = conn.cursor()
#The variables placeholder must always be a %s, psycop2 will automatically convert the values to SQL literal
query = "SELECT * FROM atrocities_details"
movies = psql.read_sql(query, conn)
movies["color"] = np.where(movies["gender"] == 'Male', "orange", "grey")
movies["alpha"] = np.where(movies["gender"] == 'Male', 0.9, 0.25)
movies.fillna(0, inplace=True) # just replace missing values with zero
axis_map = {
"Date": "date_published",
"State": "state",
"Gender": "gender",
"Religion": "religion",
"Caste": "caste"
}
desc = Div(text=open(join(dirname(__file__), "description.html")).read(), width=800)
# Create Input controls
min_date = Slider(title="Date From", start=2000, end=2017, value=2010, step=1)
max_date = Slider(title="Date To", start=2001, end=2018, value=2018, step=1)
religion = Select(title="Religion", value="All",
options=open(join(dirname(__file__), 'religion.txt')).read().split())
state = Select(title="State", value="All",
options=open(join(dirname(__file__), 'states.txt')).read().split())
incident_name = TextInput(title="Incident name contains")
x_axis = Select(title="X Axis", options=sorted(axis_map.keys()), value="Caste")
y_axis = Select(title="Y Axis", options=sorted(axis_map.keys()), value="Date")
# Create Column Data Source that will be used by the plot
source = ColumnDataSource(data=dict(x=[], y=[], color=[], title=[], alpha=[]))
hover = HoverTool(tooltips=[
("Title", "@title")
])
p = figure(plot_height=500, plot_width=500, title="", toolbar_location=None, tools=[hover])
p.circle(x="x", y="y", source=source, size=7, color="color", line_color=None, fill_alpha="alpha")
def select_movies():
religion_val = religion.value
state_val = state.value
incident_name_val = incident_name.value.strip()
# Compare form details with the database object that we created above and return the result
selected = movies[
(movies.date_published >= str(min_date.value) + "-01-01 00:00:00") &
(movies.date_published <= str(max_date.value) + "-01-01 00:00:00")
]
if (religion_val != "All"):
selected = selected[selected.religion.str.contains(religion_val)==True]
if (state_val != "All"):
selected = selected[selected.state.str.contains(state_val)==True]
if (incident_name_val != ""):
selected = selected[selected.title.str.contains(incident_name_val)==True]
return selected
def update():
df = select_movies()
x_name = axis_map[x_axis.value]
y_name = axis_map[y_axis.value]
p.xaxis.axis_label = x_axis.value
p.yaxis.axis_label = y_axis.value
p.title.text = "%d incident selected" % len(df)
source.data = dict(
x=df[x_name],
y=df[y_name],
color=df["color"],
title=df["title"],
alpha=df["alpha"]
)
controls = [religion, min_date, max_date, state, incident_name, x_axis, y_axis]
for control in controls:
control.on_change('value', lambda attr, old, new: update())
sizing_mode = 'fixed' # 'scale_width' also looks nice with this example
inputs = widgetbox(*controls, sizing_mode=sizing_mode)
l = layout([
[desc],
[inputs, p],
], sizing_mode=sizing_mode)
update() # initial load of the data
curdoc().add_root(l)
curdoc().title = "Movies"
#print(cursor.fetchone())
except psycopg2.DatabaseError as e:
print ('Error %s' % e)
sys.exit(1)
finally:
if conn:
conn.close()
我从昨天开始尝试自己调试这个问题,但没有成功,所以请帮助我。谢谢。
最佳答案
关键问题是对于分类数据,您需要明确提供 x_range 和 y_range 作为分类因子。你的情况稍微复杂一些,因为你需要动态设置分类因素,另外你还有日期作为可能的 x/y 轴。
我已经输入了一组样本数据,但由于我输入的日期,我破坏了过滤。请注意,您不能在分类轴中使用冒号,因此您必须在那里提出解决方案(也许选择日期或与数据库值相比轴的格式不同时创建日期时间轴)
from os.path import dirname, join
import sys
import time
import numpy as np
import pandas.io.sql as psql
import pandas as pd
import psycopg2
from datetime import datetime
from bokeh.plotting import figure
from bokeh.layouts import layout, widgetbox
from bokeh.models import ColumnDataSource, HoverTool, Div, FactorRange, FuncTickFormatter, FixedTicker
from bokeh.models.widgets import Slider, Select, TextInput, DatePicker, DateRangeSlider
from bokeh.io import curdoc
gender=["Male","Male","Female","Female"]
religion=['r1','r2','r1','r3']
state = ['s1','s2','s1','s3']
date=['d1','d2','d3','d4']
caste = ['c1','c2','c3','c4']
title=['t1','t2','t3','t4']
data = {'gender':gender,'religion':religion,'state':state,'date_published':date,'caste':caste,'title':title}
movies = pd.DataFrame(data)
movies["color"] = np.where(movies["gender"] == 'Male', "orange", "grey")
movies["alpha"] = np.where(movies["gender"] == 'Male', 0.9, 0.25)
movies.fillna(0, inplace=True) # just replace missing values with zero
axis_map = {
"Date": "date_published",
"State": "state",
"Gender": "gender",
"Religion": "religion",
"Caste": "caste"
}
desc = Div(text="blah blah", width=800)
# Create Input controls
min_date = Slider(title="Date From", start=2000, end=2017, value=2010, step=1)
max_date = Slider(title="Date To", start=2001, end=2018, value=2018, step=1)
religion = Select(title="Religion", value="All",
options=['r1','r2','r2'])
state = Select(title="State", value="All",
options=['s1','s2','s3'])
incident_name = TextInput(title="Incident name contains")
x_axis = Select(title="X Axis", options=sorted(axis_map.keys()), value="Caste")
y_axis = Select(title="Y Axis", options=sorted(axis_map.keys()), value="Date")
# Create Column Data Source that will be used by the plot
source = ColumnDataSource(data=dict(x=[], y=[], color=[], title=[], alpha=[]))
hover = HoverTool(tooltips=[
("Title", "@title")
])
p = figure(plot_height=500, plot_width=500, title="", toolbar_location=None, tools=[hover])
p.circle(x="x", y="y", source=source, size=7, color="color", line_color=None, fill_alpha="alpha")
def select_movies():
religion_val = religion.value
state_val = state.value
incident_name_val = incident_name.value.strip()
# Compare form details with the database object that we created above and return the result
selected = movies[
(movies.date_published >= str(min_date.value) + "-01-01 00:00:00") &
(movies.date_published <= str(max_date.value) + "-01-01 00:00:00")
]
if (religion_val != "All"):
selected = selected[selected.religion.str.contains(religion_val)==True]
if (state_val != "All"):
selected = selected[selected.state.str.contains(state_val)==True]
if (incident_name_val != ""):
selected = selected[selected.title.str.contains(incident_name_val)==True]
# ignore filtering for example plotting.
selected = movies
return selected
def update():
df = select_movies()
x_name = axis_map[x_axis.value]
y_name = axis_map[y_axis.value]
p.xaxis.axis_label = x_axis.value
p.yaxis.axis_label = y_axis.value
p.title.text = "%d incident selected" % len(df)
source.data = dict(
x=df[x_name],
y=df[y_name],
color=df["color"],
title=df["title"],
alpha=df["alpha"]
)
xticker = FixedTicker(ticks=list(range(1,len(df[x_name])+1)))
yticker = FixedTicker(ticks=list(range(1,len(df[y_name])+1)))
# func tick formatter maps each tick defined by the x/y ticker,
# then maps this to the returned value which is displayed on the
# plot
yformatter = FuncTickFormatter(args={'source':source},code="""
return source.data['y'][tick-1];
""")
xformatter = FuncTickFormatter(args={'source':source},code="""
return source.data['x'][tick-1];
""")
p.x_range = FactorRange(factors=list(df[x_name].values),bounds='auto')
p.y_range = FactorRange(factors=list(df[y_name].values),bounds='auto')
p.renderers[0].ticker = xticker
p.renderers[2].ticker = yticker
p.renderers[0].formatter = xformatter
p.renderers[2].formatter = yformatter
controls = [religion, min_date, max_date, state, incident_name, x_axis, y_axis]
for control in controls:
control.on_change('value', lambda attr, old, new: update())
sizing_mode = 'fixed' # 'scale_width' also looks nice with this example
inputs = widgetbox(*controls, sizing_mode=sizing_mode)
l = layout([
[desc],
[inputs, p],
], sizing_mode=sizing_mode)
update() # initial load of the data
curdoc().add_root(l)
curdoc().title = "Movies"
关于postgresql - 面对关于 x 轴和 y 轴(标签和范围)的 Bokeh 图的多个问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45262180/
我不能解决这个问题。和标题说的差不多…… 如果其他两个范围/列中有“否”,我如何获得范围或列的平均值? 换句话说,我想计算 A 列的平均值,并且我有两列询问是/否问题(B 列和 C 列)。我只希望 B
我知道 python 2to3 将所有 xrange 更改为 range 我没有发现任何问题。我的问题是关于它如何将 range(...) 更改为 list(range(...)) :它是愚蠢的,只是
我有一个 Primefaces JSF 项目,并且我的 Bean 注释有以下内容: @Named("reportTabBean") @SessionScoped public class Report
在 rails3 中,我在模型中制作了相同的范围。例如 class Common ?" , at) } end 我想将公共(public)范围拆分为 lib 中的模块。所以我试试这个。 module
我需要在另一个 View 范围 bean 中使用保存在 View 范围 bean 中的一些数据。 @ManagedBean @ViewScoped public class Attivita impl
为什么下面的代码输出4?谁能给我推荐一篇好文章来深入学习 javascript 范围。 这段代码返回4,但我不明白为什么? (function f(){ return f(); functio
我有一个与此结构类似的脚本 $(function(){ var someVariable; function doSomething(){ //here } $('#som
我刚刚开始学习 Jquery,但这些示例对我帮助不大...... 现在,以下代码发生的情况是,我有 4 个表单,我使用每个表单的链接在它们之间进行切换。但我不知道如何在第一个函数中获取变量“postO
为什么当我这样做时: function Dog(){ this.firstName = 'scrappy'; } Dog.firstName 未定义? 但是我可以这样做: Dog.firstNa
我想打印文本文件 text.txt 的选定部分,其中包含: tickme 1.1(no.3) lesson1-bases lesson2-advancedfurther para:using the
我正在编写一些 JavaScript 代码。我对这个关键字有点困惑。如何在 dataReceivedHandler 函数中访问 logger 变量? MyClass: { logger: nu
我有这个代码: Public Sub test() Dim Tgt As Range Set Tgt = Range("A1") End Sub 我想更改当前为“A1”的 Tgt 的引
我正忙于此工作,以为我会把它放在我们那里。 该数字必须是最多3个单位和最多5个小数位的数字,等等。 有效的 999.99999 99.9 9 0.99999 0 无效的 -0.1 999.123456
覆盖代码时: @Override public void open(ExecutionContext executionContext) { super.open(executio
我想使用 preg_match 来匹配数字 1 - 21。我如何使用 preg_match 来做到这一点?如果数字大于 21,我不想匹配任何东西。 example preg_match('([0-9]
根据docs range函数有四种形式: (range) 0 - 无穷大 (range end) 0 - 结束 (range start end)开始 - 结束 (range start end st
我知道有一个UISlider,但是有人已经制作了RangeSlider(用两个拇指吗?)或者知道如何扩展 uislider? 最佳答案 我认为你不能直接扩展 UISlider,你可能需要扩展 UICo
我正在尝试将范围转换为列表。 nums = [] for x in range (9000, 9004): nums.append(x) print nums 输出 [9000] [9
请注意:此问题是由于在运行我的修饰方法时使用了GraphQL解析器。这意味着this的范围为undefined。但是,该问题的基础知识对于装饰者遇到问题的任何人都是有用的。 这是我想使用的基本装饰器(
我正在尝试创建一个工具来从网页上抓取信息(是的,我有权限)。 到目前为止,我一直在使用 Node.js 结合 requests 和 Cheerio 来拉取页面,然后根据 CSS 选择器查找信息。我已经
我是一名优秀的程序员,十分优秀!