- utils/news.py: добавлен logger, логирование ошибок RSS - utils/cat.py: добавлен logger, логирование ошибок TheCatAPI - utils/pogoda.py: улучшены логи fallback/warning при ошибках API - utils/rate_limiter.py: debug-логи при ожидании токенов - commands/pg.py, news.py, cat.py, morning.py, status.py, stats.py: logger + логи ошибок и успешного выполнения команд - console_commands/pogoda.py, news.py, cat.py, morning.py, status.py, stats.py: logger + логи выполнения - bot.py: логи запуска/остановки, проверки конфигурации, маршрутизации консольных команд, f-строки -> %s формат - ISSUES.md: снят флаг задачи по логированию - все 243 теста пройдены
34 lines
1.3 KiB
Python
34 lines
1.3 KiB
Python
import logging
|
|
import discord
|
|
from discord.ext import commands
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
class Stats(commands.Cog):
|
|
"""Команда !stats — статистика серверов"""
|
|
|
|
@commands.command(name="stats")
|
|
async def stats(self, ctx):
|
|
"""Количество серверов, каналов и пользователей"""
|
|
guilds = ctx.bot.guilds
|
|
total_guilds = len(guilds)
|
|
total_channels = sum(
|
|
len([ch for ch in guild.channels if not isinstance(ch, discord.CategoryChannel)])
|
|
for guild in guilds
|
|
)
|
|
total_members = sum(guild.member_count or 0 for guild in guilds)
|
|
latency_ms = round(ctx.bot.latency * 1000, 1)
|
|
|
|
embed = discord.Embed(
|
|
title="Статистика серверов",
|
|
colour=discord.Color.blue(),
|
|
)
|
|
embed.add_field(name="Серверов", value=str(total_guilds), inline=True)
|
|
embed.add_field(name="Каналов", value=str(total_channels), inline=True)
|
|
embed.add_field(name="Пользователей", value=str(total_members), inline=True)
|
|
embed.add_field(name="Пинг", value=f"{latency_ms} мс", inline=True)
|
|
|
|
await ctx.send(embed=embed)
|
|
logger.info("%s: !stats выполнена", ctx.author)
|