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.