Swagger flask restplus路径变量默认值

Swagger flask restplus路径变量默认值,swagger,flask-restplus,Swagger,Flask Restplus,如何使用Flask restplus设置路径变量的默认值 例如,使用以下选项: @api.route('/calendars/coordinates/<string:latitude>/<string:longitude>/years/<string:year>') class DailyCalendarHandler(Resource): get_parser = reqparse.RequestParser() get_parser.add_arg

如何使用Flask restplus设置路径变量的默认值

例如,使用以下选项:

@api.route('/calendars/coordinates/<string:latitude>/<string:longitude>/years/<string:year>')
class DailyCalendarHandler(Resource):
  get_parser = reqparse.RequestParser()
  get_parser.add_argument('timezone', type=str, default='Asia/Calcutta', help='Example: Asia/Calcutta', location='args', required=True)
  get_parser.add_argument('encoding', type=str, default='devanagari', help='Example: iast, devanagari, kannada, tamil', location='args',
                          required=True)

  @api.expect(get_parser)
  def get(self, latitude, longitude, year):
    args = self.get_parser.parse_args()
    city = City("", latitude, longitude, args['timezone'])
get_parser = reqparse.RequestParser()
get_parser.add_argument('output_transliteration', location='args', default='devanagari', help='devanagari/slp1/iast/hk/wx/itrans/kolkata/velthuis')

您可以在类上方定义多个URL规则,并为参数定义默认值。比如:

@api.route('/calendars/coordinates', defaults={'latitude':123, 'longitude': 56})
@api.route('/calendars/latitude/<string:latitude>/longitude/<string:longitude>/years/<string:year>')
    class DailyCalendarHandler(Resource):

  def get(self, latitude, longitude, year='2017'):
@api.route('/calendars/coordinates',默认值={'latitude':123',longitude':56})
@api.route(“/日历/纬度//经度//年/”)
类DailyCalendarHandler(资源):
def get(自身、纬度、经度,2017年):

而此方法在使用
curl
的API调用方面起作用。。。生成的招摇过市ui仍然显示第二个参数,并带有
*required
标记,这让我非常恼火。@DebanjanBasu路径参数始终是必需的。不能为它们记录默认值。需要有单独的路线。