2016-07-28 5 views
1

Ich versuche eine Vorhersage-Webanwendung mit Flask zu erstellen. Die App sollte Benutzereingaben verarbeiten, sie über ein Python-trainiertes Modell verarbeiten und dann die Ergebnisse als Diagramm neben dem Eingabeformular anzeigen.Wie aktualisiert man eine bestehende Python Flask Webseite basierend auf der Formulareingabe?

Mein Code sieht wie folgt aus:

HTML Form:

<form class = "prediction-options" method = "post" action = "/prediction/results"> 
    <!--the input fields--> 
</form> 

Flask app.py

@app.route("/") 
def main(): 
    return render_template('index.html')  

@app.route("/prediction/results", methods = ['POST']) 
def predict(): 
    input_aqi = float(request.form['aqi'])/272 
    input_pm2_5 = float(request.form['pm2_5'])/224 
    input_pm10 = float(request.form['pm10'])/283 
    input_so2 = float(request.form['so2'])/36 
    input_no2 = float(request.form['no2'])/110 
    input_co = float(request.form['co'])/1.83 
    input_o3 = float(request.form['o3'])/124 
    input_list = [[input_aqi,input_pm2_5,input_pm10,input_so2,input_no2,input_co,input_o3]] 


    output_acute_bronchitis = model_acute_bronchitis.predict(input_list) 
    output_asthma = model_asthma.predict(input_list) 
    output_asthmatic_bronchitis = model_asthmatic_bronchitis.predict(input_list) 
    output_aurti = model_aurti.predict(input_list) 
    output_bronchitis = model_bronchitis.predict(input_list) 
    output_pneumonia = model_pneumonia.predict(input_list) 

    d = collections.OrderedDict() 
    d['acute_bronchitis'] = output_acute_bronchitis[0] 
    d['asthma'] = output_asthma[0] 
    d['asthmatic_bronchitis'] = output_asthmatic_bronchitis[0] 
    d['aurti'] = output_aurti[0] 
    d['bronchitis'] = output_bronchitis[0] 
    d['pneumonia'] = output_pneumonia[0] 

    prediction = jsonify(d) 
    return prediction 

Gerade jetzt, ich habe es geschafft, in dem Benutzer nehmen geben Sie die vorhergesagten Ergebnisse auf der Seite "/ prediction/results" ein und rendern Sie sie. Wie kann ich die Ergebnisse auf der Seite '/' anzeigen lassen? Ich habe versucht, dies zu tun:

@app.route("/", methods = ['POST','GET']) 
def main(): 
    if request.method == 'POST': 
     def predict(): 
      #predict function that returns prediction 
    return render_template('index.html') 

Aber ich bekomme immer eine socket.error: [Errno 32] Broken pipe Fehlermeldung. Was soll ich machen?

Antwort

1

Sie ein session dafür verwenden kann, vor der letzten Zeile in Ihrer predict Route, speichern Sie die Vorhersage mit

session['prediction'] = prediction 

und dann können Sie in jeder anderen Strecke in der Anwendung zuzugreifen, zum Beispiel können Sie dies für /

@app.route("/", methods = ['POST','GET']) 
def main(): 
    if request.method == 'POST': 
     pass 

    prediction = session['prediction'] 

    return render_template('index.html', prediction=prediction)