title: Light Up Your Data with Streamlit use_katex: False class: title-slide # Light Up Your Data with Streamlit!
data:image/s3,"s3://crabby-images/3d8d1/3d8d1dce5172376e729de193c1276400fca3da14" alt=":scale 30%"
Thomas J. Fan
@thomasjpfan
data:image/s3,"s3://crabby-images/86265/862656731a60dbd2616bfd859ea9bb720b0252b8" alt=":scale 15%"
This talk on Github: thomasjpfan/scipy-2021-streamlit
--- # What is Streamlit? ### Allows you to quickly build web applications and dashboards in `Python` .center[ data:image/s3,"s3://crabby-images/8d438/8d4380ad63c8556c71d65e7d74851094243d09bb" alt=":scale 80%" ] --- class: chapter-slide # Three Advantages of Streamlit 🚀 ### (In my opinion) --- # Regular Python Files .center[ data:image/s3,"s3://crabby-images/8d438/8d4380ad63c8556c71d65e7d74851094243d09bb" alt=":scale 90%" ] --- # Compatible with Many Visualizations Libraries .g[ .g-4[ ## Matplotlib data:image/s3,"s3://crabby-images/c68c5/c68c5c91b2cf47da50790df521f4183d31a4ee38" alt=":scale 100%" ] .g-4[ ## Plotly data:image/s3,"s3://crabby-images/2f197/2f1974209f6ef53d505f3578429178140c0136b8" alt=":scale 100%" ] .g-4[ ## Altair data:image/s3,"s3://crabby-images/b438c/b438c49ac2d8c846a558610e1b11be3f3aac8e58" alt=":scale 100%" ] ] --- # User interactions are simple to write .g[ .g-7[ ```python import os import streamlit as st *penguin = st.radio( "Select a penguin", options=["adelie", "gentoo", "chinstrap"]) st.header(f"Here is a {penguin}!") image_path = os.path.join("images", f"{penguin}.jpeg") st.image(image_path) ``` ] .g-5[ data:image/s3,"s3://crabby-images/9527c/9527cc5361713148be4bc43dc7077fd52006e98a" alt=":scale 100%" ] ] --- .g.g-center.g-middle[ .g-6[ # Streamlit's API 💻 ### Text ### Media ### User Interactions ### Visualization ### Layout ] .g-6[ data:image/s3,"s3://crabby-images/3d8d1/3d8d1dce5172376e729de193c1276400fca3da14" alt=":scale 50%" ] ] --- .g.g-middle[ .g-6.larger[ ```python import streamlit as st ``` ] .g-6.g-center[ data:image/s3,"s3://crabby-images/3d8d1/3d8d1dce5172376e729de193c1276400fca3da14" alt=":scale 40%" ### Demo materials for this talk: [github.com/thomasjpfan/scipy-2021-streamlit-demo](https://github.com/thomasjpfan/scipy-2021-streamlit-demo) ] ] --- class: chapter-slide # Text 🔠 --- # Text Demo 🔠 .g.g-middle[ .g-6[ - `st.title` - `st.header` - `st.subheader` ] .g-6[ - `st.write` - Markdown - Math - DataFrames ] ] --- class: chapter-slide # Media 📸 --- # Media Demo 📸 - `st.image` - `st.audio` - `st.video` --- class: chapter-slide # User Interactions ☎️ --- # User Interactions ☎️ .g[ .g-8[ ```python import os import streamlit as st *penguin = st.radio( "Select a penguin", options=["adelie", "gentoo", "chinstrap"]) st.header(f"Here is a {penguin}!") image_path = os.path.join("images", f"{penguin}.jpeg") st.image(image_path) ``` ] .g-4[ data:image/s3,"s3://crabby-images/9527c/9527cc5361713148be4bc43dc7077fd52006e98a" alt=":scale 100%" ] ] --- # User Interactions Demo ☎️ .g[ .g-6[ - `st.button` - `st.checkbox` - `st.radio` - `st.selectbox` - `st.multiselect` - `st.slider` - `st.select_slider` ] .g-6[ - `st.text_input` - `st.number_input` - `st.text_area` - `st.date_input` - `st.time_input` - `st.file_uploader` - `st.color_picker` ] ] --- class: chapter-slide # Visualization 📊 --- # Visualization Demo 📊 .g[ .g-4[ ## Matplotlib data:image/s3,"s3://crabby-images/c68c5/c68c5c91b2cf47da50790df521f4183d31a4ee38" alt=":scale 100%" ] .g-4[ ## Plotly data:image/s3,"s3://crabby-images/2f197/2f1974209f6ef53d505f3578429178140c0136b8" alt=":scale 100%" ] .g-4[ ## Altair data:image/s3,"s3://crabby-images/b438c/b438c49ac2d8c846a558610e1b11be3f3aac8e58" alt=":scale 100%" ] ] --- # Matplotlib: use Object-oriented API 🚨 ```python import matplotlib.pyplot as plt fig, ax = plt.subplots() ax.plot([1, 2, 3, 4]) ax.set_ylabel('some numbers') st.write(fig) ``` --- class: chapter-slide # Layout 🗄 --- # Layout Demo 🗄 - `st.sidebar` - `st.beta_columns` --- # Performance 🚀 .g[ .g-6[ - `st.cache` to cache function return values - Really useful for data loading ] .g-6[ ```python @st.cache def load_data(): data = pd.read_csv(...) return data ``` ] ] --- # Building a Machine Learning Dashboard 💻 - [A Unified Approach to Interpreting Model Predictions](https://papers.nips.cc/paper/7062-a-unified-approach-to-interpreting-model-predictions) - [Anchors: High-Precision Model-Agnostic Explanations](https://ojs.aaai.org/index.php/AAAI/article/view/11491) ```python import streamlit.components.v1 as componenets ``` --- # Streamlit Components! - Libraries with extensions built for Streamlit - Gallery: [streamlit.io/gallery?type=components](https://streamlit.io/gallery?type=components) .center[ data:image/s3,"s3://crabby-images/2073c/2073c89b6e1238ea30f087cd32b6e3670b549de9" alt=":scale 70%" ] --- # Streamlit Components Demo! - [Folium](https://python-visualization.github.io/folium/) & [streamlit-folium](https://github.com/randyzwitch/streamlit-folium) - [HiPlot](https://facebookresearch.github.io/hiplot/index.html) --- # Additional Streamlit API .g[ .g-6[ - [Session State API](https://docs.streamlit.io/en/stable/add_state_app.html) - [Forms](https://blog.streamlit.io/introducing-submit-button-and-forms/) - [Custom Themes](https://docs.streamlit.io/en/stable/theme_options.html) ] .g-6[ data:image/s3,"s3://crabby-images/3d8d1/3d8d1dce5172376e729de193c1276400fca3da14" alt=":scale 80%" ] ] --- data:image/s3,"s3://crabby-images/e0006/e0006dda0eb746dc5486c9ead9ad83ada9da1e13" alt=":scale 100%" ## [streamlit.io/sharing](https://streamlit.io/sharing) --- .center[ data:image/s3,"s3://crabby-images/faf13/faf134855ca29caa5c082276bba0be4b36c54025" alt=":scale 70%" ] ## [streamlit.io/gallery](https:/streamlit.io/gallery) --- # Other Resources to get started! - [github.com/streamlit/streamlit](https://github.com/streamlit/streamlit/) - [discuss.streamlit.io](https://discuss.streamlit.io/) .center[ data:image/s3,"s3://crabby-images/51ab1/51ab19e1d547aa49a6773c69ca258307c9cc34f6" alt=":scale 70%" ] --- class: title-slide, left .g.g-middle[ .g-7[ # Light Up Your Data with Streamlit! .center[ data:image/s3,"s3://crabby-images/3d8d1/3d8d1dce5172376e729de193c1276400fca3da14" alt=":scale 30%" ] 1. Regular Python files 2. Compatible with Many Visualizations Libraries 3. User interactions are simple to write ] .g-5.center[
.larger[Thomas J. Fan]
@thomasjpfan
data:image/s3,"s3://crabby-images/86265/862656731a60dbd2616bfd859ea9bb720b0252b8" alt=":scale 40%"
This talk on Github: github.com/thomasjpfan/scipy-2021-streamlit
] ]