python - 如何通过python电报机器人库在固定时间或间隔时间从机器人向用户发送消息?
问题描述
我正在尝试每天向机器人发送消息,而不会从第二次对话开始从用户端(例如 commandhadler)触发。
我已经为机器人构建了一个基本菜单来与用户交互
但我也在尝试每天通过 job_queue 发送消息
我参考了使用命令处理程序的代码
dp.add_handler(CommandHandler("set", set_timer,
pass_args=True,
pass_job_queue=True,
pass_chat_data=True))
这是在用户输入 /set 之后设置的。但我正在尝试找到一种方法,每 30 秒自动发送一次消息或设置固定时间每天发送消息我的代码
from telegram.ext import Updater,CommandHandler
from telegram.ext import MessageHandler,Filters,InlineQueryHandler
import logging
import telegram
logging.basicConfig(level=logging.INFO,
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger()
def start(bot, update):
update.message.reply_text("Hello , Thanks for choosing us!!")
def callback_minute(context: telegram.ext.CallbackContext):
chat_id = ?
context.bot.send_message(chat_id=chat_id,
text='Hi User, Add Fund to your account to start trading')
def main():
updater = Updater(token,use_context=True)
dp = updater.dispatcher
j = updater.job_queue
dp.add_handler(CommandHandler("start",start))
job_minute = j.run_repeating(callback_minute, interval=10, first=0)
updater.start_polling()
updater.idle()
如何获取chat_id?如果我正在使用
def callback_minute(update, context: telegram.ext.CallbackContext):
chat_id = update.message.chat.id
我收到此错误
TypeError: callback_minute() missing 1 required positional argument: 'context'
解决方案
它在下面进行了重新设计,以便从命令中调用 run_repeating() /start
(正如 Gagan TK 在评论中所建议的那样)。在此示例first=30
中,它将在 30 秒后启动。
在 GitHub 上JobQueue 的 wiki 文档底部有一个以这种方式使用作业队列的很好的示例。
from telegram.ext import Updater,CommandHandler
from telegram.ext import MessageHandler,Filters,InlineQueryHandler
import logging
import telegram
logging.basicConfig(level=logging.INFO,
format='%(asctime)s - %(name)s - %(levelname)s - %(message)s')
logger = logging.getLogger()
bot = telegram.Bot(token=token)
def start(update, context):
context.bot.send_message(chat_id=update.message.chat_id,
text="Hello , Thanks for choosing us!!")
context.job_queue.run_repeating(callback_minute, interval=10, first=30,
context=update.message.chat_id)
def callback_minute(context):
chat_id=context.job.context
context.bot.send_message(chat_id=chat_id,
text="Hi User, Add Fund to your account to start trading")
def main():
updater = Updater(token,use_context=True)
dp = updater.dispatcher
dp.add_handler(CommandHandler("start",start, pass_job_queue=True))
updater.start_polling()
updater.idle()
if __name__ == '__main__':
main()
推荐阅读
- php - Apache 每秒请求有任何限制,如何增加?
- reactjs - t.isRestProperty 不是 DestructuringTransformer.pushObjectPattern 的函数
- html - 如何将文本的有效区域限制为其兄弟图像?
- apache-spark - 如何强制 Spark SQL 进入代码生成模式?
- django - django中静态文件的正确设置是什么
- php - 简码旨在输出自定义分类法,而不是输出单词“数组”
- reactjs - 复杂的反应错误:错误:元素类型无效:期望字符串(用于内置组件)或类/函数但得到:对象
- cypress - 通过 CircleCI 执行时如何在 Cypress 中订购并行测试执行
- javascript - 使用 Typescript 强制数组中的类型
- cordova - 如何从 ionic 3 打开 google chrome 浏览器