在这一部分,我们将对我们的天气查询应用添加错误处理,以及改进用户界面。
6.1 错误处理
虽然我们已经有一个可以运行的应用,但是当前的版本还有一些问题。例如,如果用户输入了一个不存在的城市,我们的 query_weather
函数可能会抛出异常。为了解决这个问题,我们需要在视图函数中添加错误处理。
下面是一个例子:
@app.route('/search', methods=['POST'])
def search():
city = request.form['city']
try:
weather, temp_c = query_weather(city)
return f'城市:{city},天气:{weather},温度:{temp_c}°C'
except Exception:
return '抱歉,无法查询该城市的天气。'
在这个例子中,我们使用 try/except
来捕获可能的异常。如果查询天气时发生了任何异常,我们将返回一个友好的错误消息给用户。
6.2 改进用户界面
尽管我们的应用已经可以工作,但是用户界面还不够友好。例如,我们可以添加一个结果页面来显示查询结果,而不是直接在浏览器中显示文本。
首先,我们需要创建一个新的 HTML 模板 result.html
:
<!DOCTYPE html>
<html>
<head>
<title>查询结果</title>
</head>
<body>
<h1>查询结果</h1>
<p>城市:{{ city }}</p>
<p>天气:{{ weather }}</p>
<p>温度:{{ temp_c }}°C</p>
</body>
</html>
然后,我们在视图函数中使用 render_template
来渲染这个模板:
@app.route('/search', methods=['POST'])
def search():
city = request.form['city']
try:
weather, temp_c = query_weather(city)
return render_template('result.html', city=city, weather=weather, temp_c=temp_c)
except Exception:
return '抱歉,无法查询该城市的天气。'
现在,当用户查询天气时,他们将看到一个格式化的结果页面,而不是简单的文本。
以上就是如何添加错误处理和改进用户界面。在下一部分,我们将讨论如何部署我们的应用。