通过Twython在Raspberry Pi上发推文!(第2部分)

电子说

1.3w人已加入

描述

这篇文章来源于DevicePlus.com英语网站的翻译稿。 Raspberry Pi

原文最初由deviceplus.jp.发布,本文为英译版。
欢迎来到通过“Twython”在Raspberry Pi上发推文的第2部分。
和上次一样,我们将遵循Raspberry Pi 官方网站文档中的内容来完成本项目。本次,我们将介绍如何发布包含随机字符串的推文,包含图片的推文以及与如何实现流式API的连接。
本文中,我们将使用2017年11月29日发布的“Raspbian Stretch with desktop”操作系统和“Raspberry Pi2Model B”。
有关第1部分的内容,请查看→“通过Twython在Raspberry Pi上发推文!(第1部分)”

发布随机推文

第七页中的“随机发布推文信息”功能使用了Python 中的“random”模块,并使用了一个用于发布随机信息的程序。

 

01  import random
02
03  from twython import Twython
04
05  from auth import (
06
07       consumer_key,
08       consumer_secret,
09       access_token,
10       access_token_secret
11  )
12
13
14  twitter = Twython(
15      consumer_key,
16      consumer_secret,
17      access_token,
18      access_token_secret
19
20  )
21
22
23
24  messages = [
25      "Hello world",
26      "Hi there",
27      "What's up?",
28      "How's it going?",
        "Have you been here before?",
        "Get a hair cut!",
]
message = random.choice(messages)
twitter.update_status(status=message)
print("Tweeted: %s" % message)

 

然后我们将文件以“random_tweet.py”的名称保存在“/home/pi”目录中。
第3行中名为“auth”的模块就是我们上次所创建的“auth.py”。该模块将“消费者密钥(API密钥)”、“消费者秘密(API秘密)”、“访问令牌”和“访问令牌秘密”都放置在了一起。接下来,我们把该模块放入和“random_tweet.py”相同的路径中。
auth.py

 

01 consumer_key  = 'ABCDEFGHIJKLKMNOPQRSTUVWXYZ'
02 consumer_secret = '1234567890ABCDEFGHIJKLMNOPQRSTUVXYZ'
03 access_token = 'ZYXWVUTSRQPONMLKJIHFEDCBA'
04 access_token_secret = '0987654321ZYXWVUTSRQPONMLKJIHFEDCBA'

 

*将每个值替换为您在Twitter Apps上获取的值。
第2-15行和我们在上一篇文章末尾创建的Twitter发布程序(twitter.py)相同。
将“import random”添加到第一行,以能够使用随机数。在第17-24行,我们以数组的形式存储了六个信息,接下来我们在第25行中选择其中的一个信息。

Raspberry Pi图 1

输出内容为“How’s it going?”。这是存储在“messages”变量(数组)中的第四个字符串。

Raspberry Pi图 2

通过查看实际发布的推文,我们可以确认发布的内容为“How’s it going?”。虽然这是随机发布的,但是如果重复发布相同的字符串,Twitter就会报错。出现这种情况时,请隔一会再发布推文,并且尽量不要发布相同的字符串(例如,包含相同的时间或字符串)。这样一来应该能够解决该问题。

发布包含图片的推文!

在开始一个新的程序之前,我们先准备好一张图片。这次,我们将需要对文档进行调整,并将图像文件“image.png”存储到“ /home/pi/Downloads/ ”目录中。

 

from twython import Twython
from auth import
(
consumer_key,
consumer_secret,
access_token,
access_token_secret
)
twitter = Twython(
consumer_key,
consumer_secret,
access_token,
access_token_secret
)
message = "Hello world - here's a picture!"
with open('/home/pi/Downloads/raspberry.png', 'rb') as photo: twitter.update_status_with_media(status=message, media=photo)
print("Tweeted: %s" % message)

 

第17-18行需要将“update_status”改为“update_status_with_media”。

Raspberry Pi图 3

上图显示的是运行的结果。不知道为什么,出现了一些警告信息。
查看一下警告内容,其中显示当前不建议使用“update_status_with_media”函数。

Raspberry Pi图 4

虽然不推荐,但是看起来这并不影响我们成功发布推文。不过我们对于发生的状况产生了一些兴趣。查看Twython 官方网站手册之后,我们重新写了程序!

 

from twython import Twython
from auth import (
consumer_key,
consumer_secret,
access_token,
access_token_secret
twitter = Twython(
consumer_key,
consumer_secret,
access_token,
access_token_secret
message = "Hello world - here's a picture!"
photo = open('/home/pi/Downloads/raspberry.png','rb')
response = twitter.upload_media(media=photo)
twitter.update_status(status=message,
media_ids=[response['media_id']]
print("Tweeted: %s" % message)

 

查看手册中“Updating Status with Image”(使用图片更新状态)部分后,我们更改了发布推文的有关内容。
我们在“update_status”函数中添加了图像的参数后,成功发布了推文,并且没有产生任何错误!(推文与图4相同)。

实时推特操作!

我们将要介绍的最后一项内容是第九页中的“测试Twython Streamer”!
这次我们要做的是“获取”已经发布的推文,而非“发布”推文。
查看文档中的示例后,我们进行了一定程度的修改,程序源如下所示:

 

from twython import TwythonStreamer
from auth import (
consumer_key,
consumer_secret,
access_token,
access_token_secret
class MyStreamer(TwythonStreamer):
def on_success(self, data):
if 'text' in data:
username = data['user']['screen_name']
tweet = data['text']
date = data['created_at']
print("%s @%s: %s" % (date,username, tweet))
print("----------")
stream = MyStreamer(
consumer_key,
consumer_secret,
access_token,
access_token_secret
stream.statuses.filter(track='#raspberrypi')

 

首先,第1行的导入模块部分发生了变化。之前,所有的示例程序都在“Twython”类下,但本步更改为“TwythonStreamer”。
Streaming message (流式信息) 类型 — Twitter 开发者
“TwythonStreamer” 是一种用于Twitter中流式API的类。
Streaming message (流式信息)类型 — Twitter 开发者
在第9-16行,声明了名为“MyStreamer”的类。这用于在找到推文时指定操作。
在上述程序源中,除了推文的正文外,日期、账户名称和分隔线都是在输出内容中自定义的。
在第18-24行,我为新的“MyStreamer”类创建了一个实例,并开始追踪包含“# raspberrypi”的推文。

Raspberry Pi图 5

如果您找到了推文,输出将如上所示。在您停止该程序之前,它会继续获取该类型的推文(该程序似乎不区分大小写)。
寻找包含“#raspberrypi”的推文
接下来让我们访问Twitter并查看搜索结果。
您会得到部分的时间日志,不过我想从中可以大致证明这些信息是实时获取的。

总结

至此,我们结束了介绍如何使用“Twython”的第2部分。您现在可以更加轻松地在Twitter上发布和搜索推文了!
我认为基于Python的“Twython”可以很容易地应用到任何使用元器件的电子产品中。“Twython”是将通过API进行的内部处理部分与以可视化形式输出的部分之间相连接的好方法。通过发布您所拍摄的照片,或者对包含特定关键字的推文进行一些操作,您可以结合所学的知识创建出各种各样的事物!

Raspberry Pi

DevicePlus 编辑团队

设备升级版适用于所有热爱电子和机电一体化的人。

审核编辑 黄宇

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分