Как я могу вернуть нумерацию страниц как jsonify() во внешний интерфейс

#python #flask #flask-restful

#python #flask #flask-restful

Вопрос:

Это мои списки книг администратора, и я хочу добавить к ним нумерацию страниц. Как я могу добавить разбивку на страницы и вернуться в jsonify() в vue в качестве внешнего интерфейса?

 @phonebook.route('/admin/book/list')
@admin_authorize
def admin_books(user): 
    respone_body = dict()
    respone_body['status'] = "success"
    respone_body['code'] = 0
    admin_book = admin_book(user.id, sort_by_id_desc=True)
    respone_body['data']={
        'books': admin_book,
    }
    return jsonify(respone_body)


def admin_book(user_id, sort_by_id_desc=True):
    admin_books = []
    for book in Book.query.all():
        admin_books.append({
            "id": book.id,
            "name": book.name,
            "date": book.date,
        })

    return sorted(admin_books, key=lambda dict: dict['id'], reverse=sort_by_id_desc)
  

Заранее спасибо за помощь!

Комментарии:

1. Поскольку вы используете Flask-Sqlalchemy, вы можете использовать paginate метод. Обратитесь к документации .

2. Да, но я не знаю, куда добавить хахаха

Ответ №1:

Я получил ответ, и вот как я возвращаю нумерацию страниц в Flask Restful Api в jsonify(). Книга Мигеля Гринберга Flask помогла мне понять концепцию

 @phonebook.route('/admin/book/list')
@admin_authorize
   def admin_books(user): 
   respone_body = dict()
   respone_body['status'] = "success"
   respone_body['code'] = 0
   admin_book, pagination = admin_book(user.id, sort_by_id_desc=True)
   respone_body['data']={
       'books': admin_book,
       'page': pagination.page,
       'per_page': pagination.per_page,
       'total_page': pagination.pages,
   }
   return jsonify(respone_body)


def admin_book(user_id, sort_by_id_desc=True):
   admin_books = [] 
   page = request.args.get('page',1,type=int) 
   per_page = current_app.config['PER_PAGE']
   pagination = Book.query.paginate(page, per_page)
   books = pagination.items
   for book in books:
       admin_books.append({
           "id": book.id,
           "name": book.name,
           "date": book.date,
    })

   return sorted(admin_books, key=lambda dict: dict['id'], reverse=sort_by_id_desc), pagination
  

Я надеюсь, что это поможет кому-то позже, кто сделает то же самое, что и я