Flask - Regole variabili

È possibile costruire dinamicamente un URL, aggiungendo parti variabili al parametro della regola. Questa parte variabile è contrassegnata come<variable-name>. Viene passato come argomento parola chiave alla funzione a cui è associata la regola.

Nell'esempio seguente, il parametro della regola di route() decoratore contiene <name> parte variabile allegata all'URL ‘/hello’. Quindi, se il filehttp://localhost:5000/hello/TutorialsPoint è inserito come URL nel browser, ‘TutorialPoint’ sarà fornito a hello() funziona come argomento.

from flask import Flask
app = Flask(__name__)

@app.route('/hello/<name>')
def hello_name(name):
   return 'Hello %s!' % name

if __name__ == '__main__':
   app.run(debug = True)

Salva lo script sopra come hello.pyed eseguirlo dalla shell di Python. Quindi, apri il browser e inserisci l'URLhttp://localhost:5000/hello/TutorialsPoint.

Il seguente output verrà visualizzato nel browser.

Hello TutorialsPoint!

Oltre alla parte della variabile stringa predefinita, le regole possono essere costruite utilizzando i seguenti convertitori:

Sr.No. Convertitori e descrizione
1

int

accetta numeri interi

2

float

Per valore in virgola mobile

3

path

accetta le barre usate come carattere separatore di directory

Nel codice seguente vengono utilizzati tutti questi costruttori.

from flask import Flask
app = Flask(__name__)

@app.route('/blog/<int:postID>')
def show_blog(postID):
   return 'Blog Number %d' % postID

@app.route('/rev/<float:revNo>')
def revision(revNo):
   return 'Revision Number %f' % revNo

if __name__ == '__main__':
   app.run()

Esegui il codice sopra da Python Shell. Visita l'URLhttp://localhost:5000/blog/11 nel browser.

Il numero specificato viene utilizzato come argomento del file show_blog()funzione. Il browser visualizza il seguente output:

Blog Number 11

Inserisci questo URL nel browser - http://localhost:5000/rev/1.1

Il revision()la funzione assume il numero in virgola mobile come argomento. Il seguente risultato viene visualizzato nella finestra del browser:

Revision Number 1.100000

Le regole URL di Flask si basano su Werkzeug’smodulo di instradamento. Ciò garantisce che gli URL formati siano univoci e basati sui precedenti stabiliti da Apache.

Considera le regole definite nel seguente script:

from flask import Flask
app = Flask(__name__)

@app.route('/flask')
def hello_flask():
   return 'Hello Flask'

@app.route('/python/')
def hello_python():
   return 'Hello Python'

if __name__ == '__main__':
   app.run()

Entrambe le regole appaiono simili ma nella seconda regola, barra finale (/)si usa. Di conseguenza, diventa un URL canonico. Quindi, usando/python o /python/restituisce lo stesso output. Tuttavia, nel caso della prima regola,/flask/ Risultati dell'URL in 404 Not Found pagina.