- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
因此,我正在尝试使用教程、文档和在线示例的组合来自学一些 Python,以构建一个 Discord 机器人,该机器人实现了一个或多个现有机器人的某些功能。其中一个功能是将(新)推文从一组特定的 Twitter 帐户发布到我的 Discord 服务器上的特定 channel 。我找到了一些零碎的代码,我拼凑起来从 Twitter 流中读取,并在这里和那里“调整”了一些东西以尝试实现这一目标。
但是,我一直遇到实际获取 on_status
的问题。正确执行的代码。我尝试了多种方法来使其正常工作,但是我尝试的所有方法都会导致某种错误。以下是我一直在测试的最新迭代中的相关代码(已编辑):
import discord
import tweepy
from discord.ext import commands
from tweepy import Stream
from tweepy.streaming import StreamListener
class TweetListener(StreamListener):
def on_status(self, status):
if status.in_reply_to_status_id is None:
TweetText = status.text
for DGuild in MyBot.guilds:
for DChannel in DGuild.text_channels:
if DChannel.name == 'testing':
TwitterEmbed = discord.Embed(title='New Tweet', description='New Tweet from my timeline.', color=0xFF0000)
TwitterEmbed.set_author(name='@TwitterHandle', icon_url=bot.user.default_avatar_url)
DChannel.send(TweetText, embed = TwitterEmbed)
DISCORD_TOKEN = 'dtoken'
TWITTER_CONSUMER_KEY = 'ckey'
TWITTER_CONSUMER_SECRET = 'csecret'
TWITTER_ACCESS_TOKEN = 'atoken'
TWITTER_ACCESS_SECRET = 'asecret'
MyBot = commands.Bot(command_prefix='!', description='This is a testing bot')
TwitterAuth = tweepy.OAuthHandler(TWITTER_CONSUMER_KEY, TWITTER_CONSUMER_SECRET)
TwitterAuth.set_access_token(TWITTER_ACCESS_TOKEN, TWITTER_ACCESS_SECRET)
TweetAPI = tweepy.API(TwitterAuth)
NewListener = TweetListener()
NewStream = tweepy.Stream(auth=TweetAPI.auth, listener=NewListener)
NewStream.filter(follow=['USER IDS HERE'], is_async=True)
@bot.event
async def on_ready():
print(MyBot.user.name,'has successfully logged in ('+str(MyBot.user.id)+')')
print('Ready to respond')
MyBot.run(DISCORD_TOKEN)
channel.send()
当我将推文发布到我的测试帐户的时间线时,方法会生成以下消息:
RuntimeWarning: coroutine 'Messageable.send' was never awaited
我明白消息 -
channel.send()
方法是一种异步方法,但
on_status()
事件处理程序是一种同步方法,我不能
await channel.send()
内
on_status()
- 但我不知道如何让它工作。我试图制作
on_status()
方法一个异步方法:
async def on_status(self, status):
<same code for checking the tweet and finding the channel>
await DChannel.send(TweetText, embed = TwitterEmbed)
但这总是导致类似的警告:
RuntimeWarning: coroutine 'TweetListener.on_status' was never awaited
if self.on_status(status) is False:
我找到了问题,
How do I async on_status from tweepy? 并遵循那里的链接,但我没有看到任何让我知道我的编码错误的任何内容。
asyncio
的一些电话。库进行调用:
#channel.send(message, embed = TwitterEmbed)
#---ASYNCIO TEST---
loop = asyncio.get_event_loop()
loop.run_until_complete(asyncio.gather(DChannel.send(embed=TwitterEmbed)))
loop.close()
不幸的是,当它尝试执行
loop=asyncio.get_event_loop()
时,这会导致未处理的异常。指示
There is no current event loop in thread 'Thread-6'.
(所以它甚至不会使用
run_until_complete()
方法来查看它是否有效,尽管我在这一点上并不完全乐观)。
tweepy
的内容。或
discord.py
这似乎为我指明了正确的方向,而我的 Google-fu 显然没有那么强。到目前为止,我能找到的所有示例似乎都已过时,因为它们似乎指的是已弃用的方法和任一或两个库的旧版本。还有其他事情我仍然需要弄清楚如何做(例如,让
@TwitterHandle
正确填充嵌入),但我必须让它能够阅读和推送推文,然后我才能担心关于达到这一点。
TweetListener
类(class)实际上正在工作,我继续在
on_status
中注释掉了与 Discord 的所有交互。方法(从
for Guild in MyBot.guilds
到方法结束的所有内容),然后添加一个简单的
print(TweetText)
.我再次运行代码,登录到我为该项目拥有的测试 Twitter 帐户,并发布了更新。检查控制台,它正确输出
status.text
我的推文,正如我所料。正如我所想,我在这里遇到的唯一问题是试图
send
将文本发送到 Discord。
tweepy.Stream.filter
同步模式而不是异步模式 -
NewStream.filter(follow=['USER IDS'])
.这只会导致我的应用程序在启动时基本上“挂起”。我意识到这是由于它在代码中的位置,所以我移动了
TweetListener
的所有三行初始化到
on_ready
事件方法。我将 Discord 代码注释掉并进行了测试,它再次“有效”,因为它打印了
status.text
另一个测试推文到控制台。但是,机器人不会响应其他任何事情(我认为仍在“等待”流中)。
@bot.command
声明),这又一次基本上把我带回来了到我有同样问题的原始代码。
asyncio
示例并在
on_status
中的 Discord 交互中尝试了另一个迭代:
loop = asyncio.new_event_loop()
asyncio.set_event_loop(loop)
result=loop.run_until_complete(DChannel.send(embed=TwitterEmbed))
这次我遇到了与以前不同的未处理异常。错误发生在
run_until_complete
当它接收到一条新推文时:
Timeout context manager should be used inside a task
我考虑了这个进展,但我显然还没有完全到位,所以回到谷歌,我在
asgiref
上找到了信息。图书馆及其
sync_to_async
和
async_to_sync
方法,所以我想我会尝试一下。
asgiref.sync.async_to_sync(DChannel.send)(embed=TwitterEmbed)
不幸的是,我遇到了与
asyncio
相同的未处理异常。版本。我觉得我正处于解决这个问题的边缘,但它还没有“点击”。
Timeout context manager
的信息之后异常(exception),我正在超越,我偶然发现了另一个 SO 问题,它给了我一丝希望。这个答案在
RuntimeError: Timeout context manager should be used inside a task再次让我回到使用
asyncio
并在使用
asyncio.run_coroutine_threadsafe
提供有用的建议之前,简要但描述性地解释 OP 问题背后的原因。方法。查看推荐的代码,这可以帮助我有效地启动同步-> 异步方法通信是有道理的。我实现了建议的更改(为运行机器人的
Thread
对象创建了一个全局变量,添加了一个在该循环中生成机器人的“启动”方法,然后更改了
on_status
中的 Discord 交互以实现所有功能一起。
最佳答案
我遇到了和你一样的问题,并从谷歌获得了确切的链接并尝试了所有链接,但正如你所提到的,没有任何效果。
因此,经过大量的尝试和修补后我意识到,我可以将主循环传递给 tweepy 监听器并使用 run_coroutine_threadsafe 执行异步函数。
这是我的代码的要点:
听众:
class EpicListener(tweepy.StreamListener):
def __init__(self, discord, loop, *args, **kwargs):
super().__init__(*args, **kwargs)
self.discord = discord # this is just a function which sends a message to a channel
self.loop = loop # this is the loop of discord client
def on_status(self, status):
self.send_message(status._json)
def send_message(self, msg):
# Submit the coroutine to a given loop
future = asyncio.run_coroutine_threadsafe(self.discord(msg), self.loop)
# Wait for the result with an optional timeout argument
future.result()
class MyClient(discord.Client):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
async def on_ready(self):
myStream = tweepy.Stream(
auth=api.auth, listener=EpicListener(discord=self.sendtwitter, loop=asyncio.get_event_loop())
)
myStream.filter(follow=['mohitwr'], is_async=True)
print(myStream)
关于python - 使用带有 discord.py 的 tweepy 将推文发布到特定 channel ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61535485/
我正在处理一组标记为 160 个组的 173k 点。我想通过合并最接近的(到 9 或 10 个组)来减少组/集群的数量。我搜索过 sklearn 或类似的库,但没有成功。 我猜它只是通过 knn 聚类
我有一个扁平数字列表,这些数字逻辑上以 3 为一组,其中每个三元组是 (number, __ignored, flag[0 or 1]),例如: [7,56,1, 8,0,0, 2,0,0, 6,1,
我正在使用 pipenv 来管理我的包。我想编写一个 python 脚本来调用另一个使用不同虚拟环境(VE)的 python 脚本。 如何运行使用 VE1 的 python 脚本 1 并调用另一个 p
假设我有一个文件 script.py 位于 path = "foo/bar/script.py"。我正在寻找一种在 Python 中通过函数 execute_script() 从我的主要 Python
这听起来像是谜语或笑话,但实际上我还没有找到这个问题的答案。 问题到底是什么? 我想运行 2 个脚本。在第一个脚本中,我调用另一个脚本,但我希望它们继续并行,而不是在两个单独的线程中。主要是我不希望第
我有一个带有 python 2.5.5 的软件。我想发送一个命令,该命令将在 python 2.7.5 中启动一个脚本,然后继续执行该脚本。 我试过用 #!python2.7.5 和http://re
我在 python 命令行(使用 python 2.7)中,并尝试运行 Python 脚本。我的操作系统是 Windows 7。我已将我的目录设置为包含我所有脚本的文件夹,使用: os.chdir("
剧透:部分解决(见最后)。 以下是使用 Python 嵌入的代码示例: #include int main(int argc, char** argv) { Py_SetPythonHome
假设我有以下列表,对应于及时的股票价格: prices = [1, 3, 7, 10, 9, 8, 5, 3, 6, 8, 12, 9, 6, 10, 13, 8, 4, 11] 我想确定以下总体上最
所以我试图在选择某个单选按钮时更改此框架的背景。 我的框架位于一个类中,并且单选按钮的功能位于该类之外。 (这样我就可以在所有其他框架上调用它们。) 问题是每当我选择单选按钮时都会出现以下错误: co
我正在尝试将字符串与 python 中的正则表达式进行比较,如下所示, #!/usr/bin/env python3 import re str1 = "Expecting property name
考虑以下原型(prototype) Boost.Python 模块,该模块从单独的 C++ 头文件中引入类“D”。 /* file: a/b.cpp */ BOOST_PYTHON_MODULE(c)
如何编写一个程序来“识别函数调用的行号?” python 检查模块提供了定位行号的选项,但是, def di(): return inspect.currentframe().f_back.f_l
我已经使用 macports 安装了 Python 2.7,并且由于我的 $PATH 变量,这就是我输入 $ python 时得到的变量。然而,virtualenv 默认使用 Python 2.6,除
我只想问如何加快 python 上的 re.search 速度。 我有一个很长的字符串行,长度为 176861(即带有一些符号的字母数字字符),我使用此函数测试了该行以进行研究: def getExe
list1= [u'%app%%General%%Council%', u'%people%', u'%people%%Regional%%Council%%Mandate%', u'%ppp%%Ge
这个问题在这里已经有了答案: Is it Pythonic to use list comprehensions for just side effects? (7 个答案) 关闭 4 个月前。 告
我想用 Python 将两个列表组合成一个列表,方法如下: a = [1,1,1,2,2,2,3,3,3,3] b= ["Sun", "is", "bright", "June","and" ,"Ju
我正在运行带有最新 Boost 发行版 (1.55.0) 的 Mac OS X 10.8.4 (Darwin 12.4.0)。我正在按照说明 here构建包含在我的发行版中的教程 Boost-Pyth
学习 Python,我正在尝试制作一个没有任何第 3 方库的网络抓取工具,这样过程对我来说并没有简化,而且我知道我在做什么。我浏览了一些在线资源,但所有这些都让我对某些事情感到困惑。 html 看起来
我是一名优秀的程序员,十分优秀!