Skip to main content

Track & visualize user interactions with your streamlit app

Project description

streamlit-analytics  👀

PyPi

Track & visualize user interactions with your streamlit app.

This is a small extension for the fantastic streamlit framework. With just one line of code, it counts page views, tracks all user interactions with your app, and visualizes the results directly in your browser. Think Google Analytics but for streamlit.

Installation

pip install streamlit-analytics

How to use it

import streamlit as st
import streamlit_analytics

with streamlit_analytics.track():
    st.text_input("Write something")
    st.button("Click me")

That's it! 🎈 All page views and user inputs are now tracked and counted. Of course, you can also use any other streamlit widget in the with block (both from st. and st.sidebar.).

Note: One thing that doesn't work (yet) is tracking widgets created directly from containers, expanders, or columns (e.g. st.beta_expander().button("foo")). Instead, please use a with statement, e.g. with st.beta_expander(): st.button("foo").

To view the results, open your app like normal and append ?analytics=on to the URL (e.g. http://localhost:8501/?analytics=on). The results are then shown directly below your app (see image above).

More options

  • You can password-protect your analytics results with streamlit_analytics.track(unsafe_password=...). The streamlit app will then ask you for this password. Do not choose an important password here – it is sent without encryption.

  • If you don't want a huge with block, you can also do:

    import streamlit_analytics
    
    streamlit_analytics.start_tracking()
    # your streamlit code here
    streamlit_analytics.stop_tracking()
    
  • Experimental: You can store analytics results as a json file by passing save_to_json="path/to/file.json" to streamlit_analytics.track or streamlit_analytics.stop_tracking. At the moment, this may lead to problems with concurrency if many users access the site at the same time.

Next steps

PRs are welcome! If you want to work on any of these things, please open an issue to coordinate.

  • enable tracking on widgets created directly from beta_container, beta_expander, beta_columns
  • persist results after re-starting app

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

streamlit-analytics-0.1.2.tar.gz (8.0 kB view hashes)

Uploaded Source

Built Distribution

streamlit_analytics-0.1.2-py3-none-any.whl (9.4 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page