J'essaie de suivre les instructions d'utilisation de Firebase dans mon code py fonctionnant sur Raspberry Pi 2 B +. Lors de l'exécution sur python 3, de mauvaises choses se produisent.
J'ai inclus la pyrebase dans mon script mais quand je l'exécute en utilisant python3, je reçois à la place (voir ci-dessous s'il vous plaît). Je travaille sur diverses autres langues mais je viens de choisir python et Raspberry Pi pour un projet que j'avais en tête.
Ce message aura à la fois mon code et la sortie du terminal que j'obtiens lorsque j'exécute le code
#import Libraries
import RPi.GPIO as GPIO
import time
import pyrebase
import os
#Firebase Configuration
config = {
"apiKey": "apiKey",
"authDomain": "rpitest-xxxxx.firebaseapp.com",
"databaseURL": "rpitest-xxxxx.firebaseio.com",
"storageBucket": "rpitest-xxxxx.appspot.com"
}
firebase = pyrebase.initialize_app(config)
#GPIO Setup
GPIO.setmode(GPIO.BCM)
GPIO.setwarnings(False)
GPIO.setup(22, GPIO.OUT)
#Firebase Database Intialization
db = firebase.database()
#While loop to run until user kills program
while(True):
#Get value of LED
led = db.child("led").get()
#Sort through children of LED(we only have one)
for user in led.each():
#Check value of child(which is 'state')
if(user.val() == "OFF"):
#If value is off, turn LED off
GPIO.output(22, False)
else:
#If value is not off(implies it's on), turn LED on
GPIO.output(22, True)
#0.1 Second Delay
time.sleep(0.1)
pi@raspberrypi:~/Desktop/LearnPython $ Sudo python3 IoTLED.py
pi@raspberrypi:~/Desktop/LearnPython $ Sudo python3 IoTLED.py
Traceback (most recent call last):
File "IoTLED.py", line 4, in <module>
import pyrebase
File "/usr/local/lib/python3.5/distpackages/pyrebase/__init__.py", line 1, in <module>
from .pyrebase import initialize_app
File "/usr/local/lib/python3.5/distpackages/pyrebase/pyrebase.py", line 17, in <module>
from oauth2client.service_account import ServiceAccountCredentials
File "/usr/local/lib/python3.5/dist-packages/oauth2client/service_account.py", line 26, in <module>
from oauth2client import crypt
File "/usr/local/lib/python3.5/dist-packages/oauth2client/crypt.py", line 23, in <module>
from oauth2client import _pure_python_crypt
File "/usr/local/lib/python3.5/dist-packages/oauth2client/_pure_python_crypt.py", line 24, in <module>
from pyasn1_modules.rfc2459 import Certificate
File "/usr/local/lib/python3.5/dist-packages/pyasn1_modules/rfc2459.py", line 20, in <module>
from pyasn1.type import opentype
ImportError: cannot import name 'opentype'
Je suspecte que la bibliothèque d'opentype soit manquante.
Je suis vraiment vraiment vraiment coincé à ce stade depuis plus d'un jour maintenant. J'ai besoin d'aide. Merci beaucoup et j'apprécie vraiment votre aide.
J'ai eu un problème similaire, et cela l'a résolu pour moi:
pip install --upgrade google-auth-oauthlib
Il ressemble au google-auth-oauthlib
la dépendance était obsolète dans ma configuration. La version dans requirements.txt ( https://github.com/google/aiyprojects-raspbian/blob/voicekit/requirements.txt ) était 0.1.0. J'utilisais le kit vocal, mais la même chose pourrait s'appliquer à votre configuration.
Pour plus de détails, voir cette question: ImportError: impossible d'importer le nom 'opentype' sur une nouvelle installation
Voir également ceci sur le forum Raspberry Pi: https://www.raspberrypi.org/forums/viewtopic.php?f=114&t=198933&p=1241439#p1241439
Vous pouvez également essayer cela. Ça a marché pour moi.
pip install --upgrade pyasn1-modules