1
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

TIPSAdvent Calendar 2023

Day 20

【Python】streamlit で TODO アプリ

Posted at

チャット AI のインターフェイスが手軽に作れるとかで話題の streamlit ですが、簡単に UI が作れるので実は WEB アプリ開発もできるのかもしれません。

そういうわけで TODO アプリを作ってみました。

見た目

image.png

シンプルな markdown アプリみたいな見た目になりました。

コード

main.py
import streamlit as st
import pandas as pd

class TodoPage:
  def setup(self):
    if "todos" not in st.session_state:
      st.session_state.todos = pd.DataFrame([])
    def add_todo():
      st.session_state.todos = pd.concat([st.session_state.todos, pd.DataFrame([{"DONE": False, "TODO": "TODO"}])])
    self.add_todo = add_todo

  def components(self):
    st.title("TODO です")
    st.button("Add TODO", on_click=self.add_todo)
    st.session_state.todos = st.data_editor(
      st.session_state.todos, 
      hide_index=True, 
      width=500, 
      column_config={
        "DONE": {"type": "checkbox"},
        "TODO": {"type": "text"}
      }
    )

page = TodoPage()
page.setup()
page.components()

まるで Option API みたいですね!(そうか?)

setup

def setup(self):
    if "todos" not in st.session_state:
      st.session_state.todos = pd.DataFrame([])
    def add_todo():
      st.session_state.todos = pd.concat([st.session_state.todos, pd.DataFrame([{"DONE": False, "TODO": "TODO"}])])
    self.add_todo = add_todo

session_statetodos がなければ pandas.DataFrame で初期化をします。ありがたいことに、表コンポーネントが pandas.DataFrame を受け付けるためです。

add_todoは「Add TODO」ボタンを押した時に呼ばれる関数で、todos に新しい行を追加します。

注意点

ボタンクリックで add_todo を発動させた後、画面の再描画が起こり、スクリプトが再実行されます。再描画時にもデータを喪失しないためには session_state か、永続化処理を使う必要があります。

components

  def components(self):
    st.title("TODO です")
    st.button("Add TODO", on_click=self.add_todo)
    st.session_state.todos = st.data_editor(
      st.session_state.todos, 
      hide_index=True, 
      width=500, 
      column_config={
        "DONE": {"type": "checkbox"},
        "TODO": {"type": "text"}
      }
    )

コンポーネントの追加を行っています。上から順に読まれ、上から順にタイトルやボタンなどが置かれていきます。
streamlit.data_editor は表をクリックして編集したとき、編集後の値は返り値となって元のデータを破壊しません。編集結果を速やかに受け入れるためには todos に代入してやる必要があります。

おわり

あまりにも簡単すぎてびっくりしました。

1
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
1
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?