Я пытаюсь отобразить поток Twitter на матрице MAX7219 4 в 1, используя tweepy и Raspberry Pi.До сих пор я был в состоянии:
- Распечатать сообщение на матрице
- Создать стример, фильтрующий твиты, содержащие определенное слово.
Но я не уверен, как объединить все в одном скрипте.
Вот код, который я использую для печати в матрице:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import re
import time
import argparse
from luma.led_matrix.device import max7219
from luma.core.interface.serial import spi, noop
from luma.core.render import canvas
from luma.core.virtual import viewport
from luma.core.legacy import text, show_message
from luma.core.legacy.font import proportional, CP437_FONT, TINY_FONT, SINCLAIR_FONT, LCD_FONT
t_end = time.time() + 30
while time.time() < t_end:
def demo(n, block_orientation, rotate):
serial = spi(port=0, device=0, gpio=noop())
device = max7219(serial, width=8, height=32, block_orientation=block_orientation, rotate=rotate or 1)
print("Matriz creada")
msg = "FUNDACION HORIZONTAL"
print("Mensaje: " + "'" + msg + "'" + " compartido")
show_message(device, msg, fill="white", font=proportional(CP437_FONT))
time.sleep(1)
if __name__ == "__main__":
parser = argparse.ArgumentParser(description='matrix_demo arguments',
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument('--cascaded', '-n', type=int, default=1, help='Number of cascaded MAX7219 LED matrices')
parser.add_argument('--block-orientation', type=int, default=0, choices=[0, 90, -90], help='Corrects block orientation when wired vertically')
parser.add_argument('--rotate', type=int, default=0, choices=[0, 1, 2, 3], help='Rotate display 0=0°, 1=90°, 2=180°, 3=270°')
args = parser.parse_args()
try:
demo(args.cascaded, args.block_orientation, args.rotate)
except KeyboardInterrupt:
pass
И это тот, который я использую, чтобы получитьпоток:
from __future__ import absolute_import, print_function
from tweepy.streaming import StreamListener
from tweepy import OAuthHandler
from tweepy import Stream
consumer_key=""
consumer_secret=""
access_token=""
access_token_secret=""
class StdOutListener(StreamListener):
def on_status(self, status):
print(status.text)
return True
def on_error(self, status):
print(status)
if __name__ == '__main__':
l = StdOutListener()
auth = OAuthHandler(consumer_key, consumer_secret)
auth.set_access_token(access_token, access_token_secret)
stream = Stream(auth, l)
stream.filter(track=['#livinglab']
Я пытался заполнить msg со статусом:
#!/usr/bin/env python
# -*- coding: utf-8 -*-
from __future__ import absolute_import, print_function
import re
import time
import argparse
from tweepy.streaming import StreamListener
from tweepy import OAuthHandler
from tweepy import Stream
consumer_key=""
consumer_secret=""
access_token=""
access_token_secret=""
from luma.led_matrix.device import max7219
from luma.core.interface.serial import spi, noop
from luma.core.render import canvas
from luma.core.virtual import viewport
from luma.core.legacy import text, show_message
from luma.core.legacy.font import proportional, CP437_FONT, TINY_FONT, SINCLAIR_FONT, LCD_FONT
class StdOutListener(StreamListener):
def on_status(self, status):
print(status.text)
msg = status.text.encode('utf-8')
return True
def demo(n, block_orientation, rotate):
serial = spi(port=0, device=0, gpio=noop())
device = max7219(serial, width=8, height=32, block_orientation=block_orientation, rotate=rotate or 1)
print("Matriz creada")
print("Mensaje: " + "'" + msg + "'" + " compartido")
show_message(device, msg, fill="white", font=proportional(CP437_FONT))
time.sleep(1)
def on_error(self, status):
print(status)
if __name__ == "__main__":
l = StdOutListener()
auth = OAuthHandler(consumer_key, consumer_secret)
auth.set_access_token(access_token, access_token_secret)
stream = Stream(auth, l)
stream.filter(track=['#livinglab'])
parser = argparse.ArgumentParser(description='matrix_demo arguments',
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument('--cascaded', '-n', type=int, default=1, help='Number of cascaded MAX7219 LED matrices')
parser.add_argument('--block-orientation', type=int, default=0, choices=[0, 90, -90], help='Corrects block orientation when wired vertically')
parser.add_argument('--rotate', type=int, default=0, choices=[0, 1, 2, 3], help='Rotate display 0=0°, 1=90°, 2=180°, 3=270°')
args = parser.parse_args()
try:
demo(args.cascaded, args.block_orientation, args.rotate)
except KeyboardInterrupt:
pass
Есть идеи?