我有一个内联按钮分页和一个数据库. text[0],callbackdata 1我需要它们依次输出五个部分(因此直到数据库用完,它至少可以有100个元素),但我只重复了第一个元素五次,然后还有第二个,第三个,等等
cur.execute("SELECT * FROM data")
data = cur.fetchall()
def paginator(page: int=0):
builder = InlineKeyboardBuilder()
for i in range(5):
button = InlineKeyboardButton(text=data[page][0], callback_data=data[page][1])
builder.add(button)
builder.adjust(1)
builder.row(
InlineKeyboardButton(text="⬅", callback_data=kb.Pagination(action="prev", page=page).pack()),
InlineKeyboardButton(text="➡", callback_data=kb.Pagination(action="next", page=page).pack()),
width=2
)
return builder.as_markup()
@dp.callback_query(kb.Pagination.filter(F.action.in_(["prev", "next"])))
async def pagination_handler(call: CallbackQuery, callback_data: kb.Pagination):
page_num = int(callback_data.page)
page = page_num - 1 if page_num > 0 else 0
if callback_data.action == "next":
page = page_num + 1 if page_num < (len(data) - 1) else page_num
with suppress(TelegramBadRequest):
await call.message.edit_text(
f"list",
reply_markup=paginator(page)
)
await call.answer()
@dp.message()
async def echo(message: Message):
msg = message.text.lower()
if msg == "list":
await message.answer("lis", reply_markup=paginator(0))
1条答案
按热度按时间2admgd591#
据我所知,我们的两个解决方案都基于相同的代码,所以这就是我是如何做到这一点的,它可能会有所帮助:
字符串
要显示查询中的前5条记录,您应该执行以下操作:
型