Как исправить AttributeError: объект 'module' не имеет атрибута 'Client' при запуске python в Google Cloud Interactive Shell

Я пытаюсь запустить скрипт python, который имитирует отправку данных датчиками трафика в реальном времени в PubSub в моей облачной оболочке Google. Я получаю эту ошибку

Traceback (most recent call last):
  File "./send_sensor_data.py", line 87, in <module>
    psclient = pubsub.Client()
AttributeError: 'module' object has no attribute 'Client'

Пробовал запустить google.cloud.pubsub.__file__, дубликатов нет. Я искал повсюду, и все согласились с тем, что пакет pubsub нужно установить в виртуальную среду, но безуспешно. Что я пробовал до сих пор:

  • Установите виртуальную машину в чистое состояние
  • Удалены и переустановлены все компоненты gcloud
  • Обновлены все компоненты gcloud до последней версии
  • неустановленная и переустановленная библиотека pubsub python
  • Установлен pubsub внутри virtualenv
  • Пробовал из другого проекта
  • Пробовали с другой учетной записи GCP

Это мой сценарий:

import time
import gzip
import logging
import argparse
import datetime
from google.cloud import pubsub

TIME_FORMAT = '%Y-%m-%d %H:%M:%S'
TOPIC = 'sandiego'
INPUT = 'sensor_obs2008.csv.gz'

def publish(topic, events):
   numobs = len(events)
   if numobs > 0:
      with topic.batch() as batch:
         logging.info('Publishing {} events from {}'.
                    format(numobs, get_timestamp(events[0])))
         for event_data in events:
              batch.publish(event_data)

def get_timestamp(line):
   # look at first field of row
   timestamp = line.split(',')[0]
   return datetime.datetime.strptime(timestamp, TIME_FORMAT)

def simulate(topic, ifp, firstObsTime, programStart, speedFactor):
   # sleep computation
   def compute_sleep_secs(obs_time):
        time_elapsed = (datetime.datetime.utcnow() - programStart).seconds
        sim_time_elapsed = (obs_time - firstObsTime).seconds / speedFactor
        to_sleep_secs = sim_time_elapsed - time_elapsed
        return to_sleep_secs

   topublish = list() 

   for line in ifp:
       event_data = line   # entire line of input CSV is the message
       obs_time = get_timestamp(line) # from first column

       # how much time should we sleep?
       if compute_sleep_secs(obs_time) > 1:
          # notify the accumulated topublish
          publish(topic, topublish) # notify accumulated messages
          topublish = list() # empty out list

          # recompute sleep, since notification takes a while
          to_sleep_secs = compute_sleep_secs(obs_time)
          if to_sleep_secs > 0:
             logging.info('Sleeping {} seconds'.format(to_sleep_secs))
             time.sleep(to_sleep_secs)
       topublish.append(event_data)

   # left-over records; notify again
   publish(topic, topublish)

def peek_timestamp(ifp):
   # peek ahead to next line, get timestamp and go back
   pos = ifp.tell()
   line = ifp.readline()
   ifp.seek(pos)
   return get_timestamp(line)


if __name__ == '__main__':
   parser = argparse.ArgumentParser(description='Send sensor data to Cloud Pub/Sub in small groups, simulating real-time behavior')
   parser.add_argument('--speedFactor', help='Example: 60 implies 1 hour of data sent to Cloud Pub/Sub in 1 minute', required=True, type=float)
   args = parser.parse_args()

   # create Pub/Sub notification topic
   logging.basicConfig(format='%(levelname)s: %(message)s', level=logging.INFO)
   psclient = pubsub.Client()
   topic = psclient.topic(TOPIC)
   if not topic.exists():
      logging.info('Creating pub/sub topic {}'.format(TOPIC))
      topic.create()
   else:
      logging.info('Reusing pub/sub topic {}'.format(TOPIC))

   # notify about each line in the input file
   programStartTime = datetime.datetime.utcnow() 
   with gzip.open(INPUT, 'rb') as ifp:
      header = ifp.readline()  # skip header
      firstObsTime = peek_timestamp(ifp)
      logging.info('Sending sensor data from {}'.format(firstObsTime))
      simulate(topic, ifp, firstObsTime, programStartTime, args.speedFactor)

person Judy T Raj    schedule 18.11.2017    source источник


Ответы (3)


Класс pubsub.Client существует до версии 0.27.0 пакета python pubsub. Итак, я просто создал виртуальную среду и установил в нее версию pubsub 0.27.0. Вот команды:

virtualenv venv
source venv/bin/activate
pip install google-cloud-pubsub==0.27.0
person Judy T Raj    schedule 21.11.2017

Решение для Google Cloud Platforms:

  1. Измените файл send_senor_data.py следующим образом:

    а. Прокомментируйте исходный оператор импорта для pub_sub и используйте версию _v1

      #from google.cloud import pubsub
       from google.cloud import pubsub_v1
    

    б. Найдите этот код и замените его следующим образом:

      #publisher = pubsub.PublisherClient()
      publisher = pubsub_v1.PublisherClient()
    
    1. Then execute your send_sensor_data.py as follows:

      ./send_sensor_data.py --speedFactor = 60 --project = ВАШ-НАЗВАНИЕ-ПРОЕКТА

person Samir Shrouti    schedule 14.07.2019

Нет pubsub.Client класса. Вам нужно выбрать PublisherClient или SubscriberClient

см. https://github.com/GoogleCloudPlatform/google-cloud-python/blob/master/pubsub/google/cloud/pubsub.py

person stacksonstacks    schedule 18.11.2017