RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1603260
Accepted
Клим
Клим
Asked:2024-12-24 19:43:28 +0000 UTC2024-12-24 19:43:28 +0000 UTC 2024-12-24 19:43:28 +0000 UTC

帮我完成机器人代码

  • 772

请帮我完成机器人。这个阶段会报错:

c:\Users\Klim\Desktop\NewBot.py:96: RuntimeWarning: coroutine 'main' was never awaited main() RuntimeWarning: Enable tracemalloc to get the object allocation traceback

这是代码:

import requests
import logging
from telegram import Update
from telegram.ext import ApplicationBuilder, CommandHandler, ContextTypes, MessageHandler, filters
import asyncio

# Включаем логирование
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
                    level=logging.INFO)

logger = logging.getLogger(__name__)

# Конфигурация
TOKEN = 'YOUR_TELEGRAM_BOT_TOKEN'  # Замените на фактический токен вашего бота
REGION = 'ru'                       # Регион, например, 'eu'

# Используем словарь для хранения отслеживаемых параметров для каждого чата
chat_data = {}

async def start(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
    await update.message.reply_text('Привет! Я бот для отслеживания аукционных лотов. '
                                    'Используйте команду /track <item> <price> для начала отслеживания, '
                                    'например: /track helmet 150')


async def check_auctions(context: ContextTypes.DEFAULT_TYPE) -> None:
    chat_id = context.job.context
    if chat_id not in chat_data or not chat_data[chat_id].get('item') or not chat_data[chat_id].get('price_threshold'):
        return

item = chat_data[chat_id]['item']
price_threshold = chat_data[chat_id]['price_threshold']
previous_lots = chat_data[chat_id].get('previous_lots', [])
 
url = f"https://eapi.stalcraft.net/{REGION}/auction/{item}/lots"
try:
    response = requests.get(url)
    response.raise_for_status()  # Raise HTTPError for bad responses (4xx or 5xx)
    data = response.json()

    if 'data' in data and data['data']:
        lots = data['data']
        for lot in lots:
            if lot['price'] <= price_threshold and lot not in previous_lots:
                await context.bot.send_message(chat_id=chat_id, text=f"Новый лот найден: {lot}")
                previous_lots.append(lot)
        
        if len(previous_lots) > 10:
            previous_lots.pop(0)


        chat_data[chat_id]['previous_lots'] = previous_lots
    else:
        logger.warning(f"No data found for item: {item} in chat_id: {chat_id}")

except requests.exceptions.RequestException as e:
    logger.error(f"Error fetching auction data: {e} for chat_id: {chat_id}")
except ValueError as e:
    logger.error(f"Error parsing json response {e} for chat_id: {chat_id}")



async def track_item(update: Update, context: ContextTypes.DEFAULT_TYPE) -> None:
    chat_id = update.message.chat.id
    try:
        item = context.args[0]
        price_threshold = int(context.args[1])
    except (IndexError, ValueError):
        await update.message.reply_text('Пожалуйста, используйте команду /track <item> <price>, например: /track helmet 150')
        return
    
    if chat_id not in chat_data:
        chat_data[chat_id] = {}

    chat_data[chat_id]['item'] = item
    chat_data[chat_id]['price_threshold'] = price_threshold
    chat_data[chat_id]['previous_lots'] = [] # reset previous lots if we are starting a new tracking

    
    if 'job' in chat_data[chat_id] and chat_data[chat_id]['job']:
            chat_data[chat_id]['job'].schedule_removal()  # Remove the existing job if one exists
    
    job = context.job_queue.run_repeating(check_auctions, interval=10, first=0, context=chat_id)
    chat_data[chat_id]['job'] = job
    await update.message.reply_text(f'Начинаю отслеживание лотов для предмета {item} по цене не выше {price_threshold}!')

async def main() -> None:
    app = ApplicationBuilder().token(TOKEN).build()

    app.add_handler(CommandHandler("start", start))
    app.add_handler(CommandHandler("track", track_item))

    await app.run_polling()

if __name__ == '__main__':
    main() 

预先感谢您的帮助。

python
  • 1 1 个回答
  • 28 Views

1 个回答

  • Voted
  1. Best Answer
    CrazyElf
    2024-12-24T19:59:22Z2024-12-24T19:59:22Z
    async def main() -> None:
        ...
    if __name__ == '__main__':
        main() 
    

    运行时警告:从未等待过协程“main”

    好吧,因为异步函数main也必须异步运行:

    asyncio.run(main())
    

    尽管在您的情况下,相反,您需要使其main不是异步函数,而是常规函数:

    def main() -> None:
        app = ApplicationBuilder().token(TOKEN).build()
    
        app.add_handler(CommandHandler("start", start))
        app.add_handler(CommandHandler("track", track_item))
    
        app.run_polling()
    

    至少从这个例子来看。

    • 0

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5