Análisis de viajes
El fondo de cobertura apunta alto y quiere entender el rendimiento de las acciones de aerolíneas.
Vas a crear un gráfico de líneas de precio de la acción frente a fecha, permitiendo cambiar entre Delta Air Lines, Southwest Airlines y Boeing. La figura y los glifos ya están precargados para ti:
boeing = stocks.loc[stocks["name"] == "BA"]
delta = stocks.loc[stocks["name"] == "DAL"]
southwest = stocks.loc[stocks["name"] == "LUV"]
fig = figure(x_axis_label="Date", y_axis_label="Stock Price",
x_axis_type="datetime")
boeing_line = fig.line(x=boeing["date"], y=boeing["close"],
alpha=0.5)
delta_line = fig.line(x=delta["date"], y=delta["close"],
color="red", alpha=0.5)
sw_line = fig.line(x=southwest["date"], y=southwest["close"],
color="green", alpha=0.5)
Este ejercicio forma parte del curso
Visualización de datos interactiva con Bokeh
Instrucciones del ejercicio
- Importa el widget
Selectjunto conCustomJS. - Crea el widget
Select, asignandooptionscomo una lista que contenga"Boeing","Delta"y"Southwest"(en ese orden), unvaluede"Boeing"y untitlede"Airline". - Configura el widget para ejecutar la función
callbackcuando cambie"value".
Ejercicio interactivo práctico
Prueba este ejercicio y completa el código de muestra.
# Import modules
____
# Create Select widget
menu = ____(____=["____", "____", "____"], ____="____", ____="____")
callback = CustomJS(args=dict(line_1=boeing_line, line_2=delta_line,
line_3=sw_line), code="""
line_1.visible = true
line_2.visible = true
line_3.visible = true
if (this.value == "Boeing") {line_2.visible = false
line_3.visible = false}
else {line_1.visible = false}
if (this.value == "Delta") {line_1.visible = false
line_3.visible = false}
else {line_2.visible = false}
if (this.value == "Southwest") {line_1.visible = false
line_2.visible = false}
else {line_3.visible = false}
""")
# Set up interaction
menu.____("____", ____)
output_file(filename="airline_stocks.html")
show(column(menu, fig))