将数据从HTML表单发送到Flask中的Python脚本


80

我的Python脚本中有以下代码:

def cmd_wui(argv, path_to_tx):
    """Run a web UI."""
    from flask import Flask, flash, jsonify, render_template, request
    import webbrowser
    app = Flask(__name__)


    @app.route('/tx/index/')
    def index():
        """Load start page where you select your project folder
        or load history projects from local DB."""
        from txclib import get_version
        txc_version = get_version()
        prj = project.Project(path_to_tx)

        # Let's create a resource list from our config file
        res_list = []
        prev_proj = ''
        for idx, res in enumerate(prj.get_resource_list()):
                hostname = prj.get_resource_host(res)
        username, password = prj.getset_host_credentials(hostname)
        return render_template('init.html', txc_version=txc_version, username=username)

另外,我在init.html中有一个HTML表单:

<form>
<input type="text" id="projectFilepath" size="40" placeholder="Spot your project files">
<input type="button" id="spotButton" value="Spot">
</form>

当用户在python脚本中的变量上单击“ spotButton”时,如何传递来自“ projectFilepath”的用户输入?

我是Python和Flask的新手,所以如果我犯任何错误,请原谅我。


1
您的projectFilepath输入需要name设置属性-然后您可以访问中的值request.args.value_of_name(或request.form.value_of_name进行POST请求
。-Sean Vieira 2012年

1
我想指出您使用标记id上的属性的微妙之处<input>,而下面的答案使用namename就是您想要的,因为这就是通过键输入的内容request.form
特伦顿

Answers:


146

form标记需要两个属性进行设置:

  1. action:表单数据在提交时发送到的URL。用生成它url_for。如果相同的URL处理显示表单和处理数据,则可以将其省略。
  2. method:是将数据作为查询字符串(GET)还是作为表单数据(POST)提交。

input标签需要一个name参数。

添加一个视图来处理提交的数据,该视图request.form位于与输入相同的键下name

@app.route('/handle_data', methods=['POST'])
def handle_data():
    projectpath = request.form['projectFilepath']
    # your code
    # return a response

使用以下命令将表单设置action为该视图的URL url_for

<form action="{{ url_for('handle_data') }}" method="post">
    <input type="text" name="projectFilepath">
    <input type="submit">
</form>

7
method实际上是可选的-默认为GET。否则,您会发现。
肖恩·维埃拉

4
作为一个菜鸟(实际上是在Flask上工作的第一天),我最初并没有意识到必须做的事情from flask import Flask, request
CodeFinity

3
我更喜欢使用request.form.get('projectFilepath')而不是request.form['projectFilepath']避免发送空值时获取异常。
Ibrahim.H

2
还要注意的另一件事是url_for使用该名称查找该函数,因此此处的视图应命名为handle_data
TrigonaMinima

56

您需要一个可以接收POST数据的Flask视图,以及一个可以发送它的HTML表单。

from flask import request

@app.route('/addRegion', methods=['POST'])
def addRegion():
    ...
    return (request.form['projectFilePath'])
<form action="{{ url_for('addRegion') }}" method="post">
    Project file path: <input type="text" name="projectFilePath"><br>
    <input type="submit" value="Submit">
</form>
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.