Developing simple interactive Web application with Python

Today, share a super simple tool for developing interactive web apps. No, HTML, CSS, JAVASCRIPT are fine.

Interactive Web app is very practical, such as making a questionnaire page, a voting system, an information collection form, uploading files, etc. because the web page is visual, it can also be used as a picture interface application without a server.

If you have such development requirements, it's really too easy to use Python.

With the help of PyWebIO (pip install pywebio), you can enter web page information in minutes. You can see the following dynamic diagram:

The above page only uses these 6 lines of code:

from pywebio.input import *

input("This is a simple text input")
select("This is a drop down menu", ['Option1', 'Option2'])
checkbox("Multiple Choices!", options=["a",'b','c','d'])
radio("Select any one", options=['1', '2', '3'])
textarea('Text Area', rows=3, placeholder='Multiple line text input')

It is also very simple to make the web page output the desired information. The code is as follows. The function functions have been annotated, which is easy for you to understand:

from pywebio.output import *
from pywebio import session

# Display plain text on Web pages
put_text("Hello friend!")

# Show table on Web page
put_table([
    ['Object', 'Unit'],
    ['A', '55'],
    ['B', '73'],
])

# MarkDown is displayed on the web page
put_markdown('~~PyWebIO~~')

# A link to download the file is displayed on the web page
put_file('output_file.txt', b'You can put anything here')

# Show pictures on Web pages
put_image(open('python_logo.png', 'rb').read())

# Pop up window on Web page
popup('popup title', 'popup text content')

# Keep the reply open, otherwise the page is displayed and the program exits
session.hold()

The effect of operation is as follows:

Above, a few lines of code realize a Web application with input and output. Isn't it amazing?

Building browser based GUI programs

PyWebIO provides a series of command-based interactive functions to obtain user input and output on the browser, turning the browser into a "rich text terminal", which can be used to build simple Web applications or browser based GUI applications.

For example, the script for calculating BMI index:

from pywebio import start_server
from pywebio.input import input, FLOAT
from pywebio.output import put_text

def bmi():
    height = input("Please enter your height(cm): ", type=FLOAT)
    weight = input("Please enter your weight(kg): ", type=FLOAT)

    BMI = weight / (height / 100) ** 2

    top_status = [(14.9, 'Extremely thin'), (18.4, 'Thin '),
                  (22.9, 'normal'), (27.5, 'overweight'),
                  (40.0, 'Obesity'), (float('inf'), 'Very fat')]

    for top, status in top_status:
        if BMI <= top:
            put_text('Yours BMI value: %.1f,Physical condition:%s' % (BMI, status))
            break

if __name__ == '__main__':
    start_server(bmi, port=80)

effect:

More examples:

Basic demo

  • Chat room: chat with all current online people (less than 90 lines of code)
  • Markdown real-time preview: an online markdown editor that can be previewed in real time (implemented in less than 40 lines of code)
  • Online Gobang game: a Gobang game in which many people cooperate against each other (implemented in less than 100 lines of code)
  • Input demonstration: demonstrate the usage of the PyWebIO input module
  • Output demonstration: demonstrate the usage of PyWebIO output module

Data visualization demo

PyWebIO also supports data visualization using third-party libraries

  • Data visualization using bokeh
  • Data visualization using plot
  • Using pyecharts to create an Echarts based chart
  • Create G2Plot based charts using pyg2plot
  • Use cutcharts Py create cartoon style chart

Data visualization rendering:

Integration with existing frameworks

PyWebIO can also be easily integrated into existing Web services, so that you can build applications with good usability without writing HTML and JS code. At present, it supports integration with Flask, Django, Tornado, aiohttp and FastAPI frameworks.

For example, integration with Tornado applications:

import tornado.ioloop
import tornado.web
from pywebio.platform.tornado import webio_handler

class MainHandler(tornado.web.RequestHandler):
    def get(self):
        self.write("Hello, world")

if __name__ == "__main__":
    application = tornado.web.Application([
        (r"/", MainHandler),
        (r"/bmi", webio_handler(bmi)),  # BMI is a function of the BMI index calculated above
    ])
    application.listen(port=80, address='localhost')
    tornado.ioloop.IOLoop.current().start()

Integration with Django:

# urls.py

from django.urls import path
from pywebio.platform.django import webio_view

# `task_func` is PyWebIO task function
webio_view_func = webio_view(task_func)

urlpatterns = [
    path(r"tool", webio_view_func),
]

last

PyWebIO uses synchronization rather than callback based method to obtain input. The code writing logic is more natural and non declarative layout. The layout method is simple and efficient, and the code is less invasive. The old script code can be transformed into a Web service by modifying the input and output logic, and can also be integrated into the existing mainstream Web framework. At the same time, it supports thread based execution model and co process based execution model, and supports data visualization combined with third-party library

In a word, PyWebIO makes interactive Web development easier, especially suitable for developing simple GUI programs and data visualization.

Keywords: Python

Added by yzerman on Mon, 27 Dec 2021 12:26:47 +0200