Python 如何使用Flask和HTML在同一网页上打印/显示我的搜索结果?

Python 如何使用Flask和HTML在同一网页上打印/显示我的搜索结果?,python,html,flask,Python,Html,Flask,我有一个球员数据集和他们进球的数量,这个数据集存储在一个数据框中。我想显示或打印我在搜索栏上搜索的统计数据和球员详细信息,但我总是收到一个错误的请求 这是数据集 这就是网页的样子 MainProject Python文件 import pandas as pd from pandas import DataFrame from fuzzywuzzy import process scorers=pd.read_csv('tests.csv') de

我有一个球员数据集和他们进球的数量,这个数据集存储在一个数据框中。我想显示或打印我在搜索栏上搜索的统计数据和球员详细信息,但我总是收到一个错误的请求

这是数据集

这就是网页的样子

MainProject Python文件

    import pandas as pd
    from pandas import DataFrame
    from fuzzywuzzy import process



    scorers=pd.read_csv('tests.csv')

    def main(searchplayer):
        scorers=pd.read_csv('tests.csv')
        player=list(scorers['Player'])
        goals=list(scorers['Goals'])
        team=list(scorers['Team'])


        df_data={'player': player,
                'goals': goals,
                'team': team}

        df_main=pd.DataFrame(df_data, columns=['player', 'goals', 'team'])
        def getSearchedProducts(searchplayer, choices, limit=30):
            res=process.extract(searchplayer, choices, limit=limit)
            return res

        searchplayer=str(searchplayer)
        result=getSearchedProducts(searchplayer, player)

        player_result_list = [res[0] for res in result if res[1]>=70]

        player_result_df = df_main[df_main['Product'].isin(product_result_list)]

        player_result_df.index+=1
        list_player_res=[(tabulate(player_result_df, headers='keys', tablefmt='psql'))]

        return list_player_res
烧瓶锉

    import os
    from flask import Flask, flash, request, render_template, 
            redirect, url_for, send_from_directory
    from werkzeug.utils import secure_filename
    from MainProject import main
    from flask_cors import CORS

    searchplayer=""

    app=Flask(__name__)

    app.config['CACHE_TYPE']='null'
    CORS(app)

    @app.route('/', methods=['GET', 'POST'])
    def homepage():
        searchplayer=request.form['prod']
        list_player_res = main(searchplayer)
        return render_template('home.html', list_player_res=list_player_res)

    if __name__ == "__main__":
        app.run()
我的Html文件的代码片段

    <form class="form-inline" method="POST">
            <input class="form-control mr-sm-2" name="prod" type="search" placeholder="Search for Players" aria-label="Search">
            <button class="btn btn-light my-sm-0" type="Submit">Search</button>  
          </form>           
HTML这就是我所做的:

          <form class="form-inline" method="POST">
                    <input class="form-control mr-sm-2" name="prod" 
    type="search" placeholder="Search for Players" aria-label="Search">
                    <button class="btn btn-light my-sm-0" 
       type="Submit">Search</button>  
                  </form>  
                </div>
              </nav>

            <br> 
            {% for result in list_player_res %} 
                    {{result}}
                 {% endfor %}   
            </br>

搜寻

{列表中的结果为%_player_res%} {{result}} {%endfor%}

如何在该搜索栏中搜索玩家,并将结果显示在同一屏幕上?

您的路线不会区分get和POST请求。您需要在
if request.method=='POST':
保护中屏蔽需要表单输入的部分,否则最初尝试加载页面时会出现错误这是否回答了您的问题?不,没有。它不能打印/显示输出。好了,现在来吧,你需要给我一些东西来处理。这几乎肯定是你的问题,但我看不出你是如何试图实施它的,或者isI看不到的问题是什么。请回答这个问题
          <form class="form-inline" method="POST">
                    <input class="form-control mr-sm-2" name="prod" 
    type="search" placeholder="Search for Players" aria-label="Search">
                    <button class="btn btn-light my-sm-0" 
       type="Submit">Search</button>  
                  </form>  
                </div>
              </nav>

            <br> 
            {% for result in list_player_res %} 
                    {{result}}
                 {% endfor %}   
            </br>