from fastai.vision.all import * from io import BytesIO import requests import streamlit as st """ # 貓咪種類辨識 可以辨識布偶貓、緬因貓、銀漸層英短這三種貓。 """ def predict(img): st.image(img, caption="Your image", use_column_width=True) pred, key, probs = learn_inf.predict(img) # st.write(learn_inf.predict(img)) f""" ## This **{'is 布偶貓' if pred == '布偶貓 ' else 'is 緬因貓' if pred == '緬因貓' else 'is 銀漸層英短'}**. ### Prediction result : {pred} ### Probability of {pred}: {probs[key].item()*100: .2f}% """ path = "./" learn_inf = load_learner(path + "demo_model.pkl") option = st.radio("", ["Upload Image", "Image URL"]) if option == "Upload Image": uploaded_file = st.file_uploader("Please upload an image.") if uploaded_file is not None: img = PILImage.create(uploaded_file) predict(img) else: url = st.text_input("Please input a url.") if url != "": try: response = requests.get(url) pil_img = PILImage.create(BytesIO(response.content)) predict(pil_img) except: st.text("Problem reading image from", url)