How do I embed an existing non streamlit webpage to my streamlit app

Demo with solution & code sample:

https://shinosuke-lab-2.streamlit.app/

Iframe embedding:

For the iframe you can try something like this:

import streamlit as st
import streamlit.components.v1 as components

def run():
    iframe_src = "https://open.spotify.com/embed/track/59BweHnnNQc5Y55WO30JuK?utm_source=generator"
    components.iframe(iframe_src)
   # You can add height and width to the component of course.

if __name__ == "__main__":
    run()

Whole HTML embedding:

As you can read on the Streamlit app I deployed, there’s always a problem with embedding full HTML pages, so you’ll have to find a workaround on your own.

I suggest here (for HTML embedding not iframe) to build an inner HTML component (a webpage within your Streamlit app).
If you BUILD and entire HTML yourself within your app (for structuring purposes and clean code, you can put it in a side file, e.g: html.py and call it within your main app.py), it will render fine as a HTML component unlike calling a webpage from somewhere else (some website work).

PS: You can still embed your GitHub Pages website, even if you use a custom domain name. I personally have few static pages, and tried both a GH Pages with its native github.io URL and a GH Page with a custom domain using porkbun.com, both have HTTPS enabeled, and both were embedded as iframes while if you try to embed https://discuss.streamlit.io it won’t work.

3 Likes