Tweepy ответ на упоминания бота - PullRequest
0 голосов
/ 30 января 2020

Когда я запускаю этот скрипт, чтобы ответить на упоминания в Твиттере с помощью Tweepy, я получаю сообщение об ошибке NameError: имя 'create_api' не определено, и я не уверен, почему. Что мне здесь не хватает? Любая помощь будет принята с благодарностью. Спасибо

import tweepy
import logging
import time

def create_api():
    consumer_key = 'xxxxx'
    consumer_secret = 'xxxxx'
    access_token = 'xxxx-xxxx'
    access_token_secret = 'xxxx'

auth = tweepy.OAuthHandler(consumer_key, consumer_secret)
auth.set_access_token(access_token, access_token_secret)
api = tweepy.API(auth, wait_on_rate_limit=True, 
wait_on_rate_limit_notify=True)
try:
    api.verify_credentials()
    except Exception as e:
        logger.error("Error creating API", exc_info=True)
        raise e
    logger.info("API created")
    return api

def check_mentions(api, keywords, since_id):
    logger.info("Retrieving mentions")
    new_since_id = since_id
    for tweet in tweepy.Cursor(api.mentions_timeline,
        since_id=since_id).items():
        new_since_id = max(tweet.id, new_since_id)
        if tweet.in_reply_to_status_id is not None:
            continue
        if any(keyword in tweet.text.lower() for keyword in keywords):
            logger.info(f"Answering to {tweet.user.name}")

            if not tweet.user.following:
                tweet.user.follow()

            api.update_status(
                status="Please reach us via DM",
                in_reply_to_status_id=tweet.id,
            )
    return new_since_id

def main():
    api = create_api()
    since_id = 1
    while True:
        since_id = check_mentions(api, ["help", "support"], since_id)
        logger.info("Waiting...")
        time.sleep(60)

if __name__ == "__main__":
    main()

1 Ответ

0 голосов
/ 30 января 2020

Кажется, что большинство ваших ошибок происходят из-за неправильного отступа. Вот версия вашего кода, где я исправил проблемы с отступами.

Я получаю NameError: name 'logger' is not defined, потому что правильный метод использования библиотеки logging состоит в использовании logging.x вместо logger. Кажется, это небольшая опечатка.

После исправления я получаю tweepy.error.TweepError: [{'code': 89, 'message': 'Invalid or expired token.'}], что и следовало ожидать, потому что у меня нет действительного токена.

import tweepy
import logging
import time

def create_api():
    consumer_key = 'xxxxx'
    consumer_secret = 'xxxxx'
    access_token = 'xxxx-xxxx'
    access_token_secret = 'xxxx'

    auth = tweepy.OAuthHandler(consumer_key, consumer_secret)
    auth.set_access_token(access_token, access_token_secret)
    api = tweepy.API(auth, wait_on_rate_limit=True, 
    wait_on_rate_limit_notify=True)
    try:
        api.verify_credentials()
    except Exception as e:
        logging.error("Error creating API", exc_info=True)
        raise e
    logging.info("API created")
    return api

def check_mentions(api, keywords, since_id):
    logging.info("Retrieving mentions")
    new_since_id = since_id
    for tweet in tweepy.Cursor(api.mentions_timeline,
        since_id=since_id).items():
        new_since_id = max(tweet.id, new_since_id)
        if tweet.in_reply_to_status_id is not None:
            continue
        if any(keyword in tweet.text.lower() for keyword in keywords):
            logging.info(f"Answering to {tweet.user.name}")

            if not tweet.user.following:
                tweet.user.follow()

            api.update_status(
                status="Please reach us via DM",
                in_reply_to_status_id=tweet.id,
            )
    return new_since_id

def main():
    api = create_api()
    since_id = 1
    while True:
        since_id = check_mentions(api, ["help", "support"], since_id)
        logging.info("Waiting...")
        time.sleep(60)

if __name__ == "__main__":
    main()

Вывод: (чтобы показать, что протоколирование фиксирует ошибку)

ERROR:root:Error creating API
Traceback (most recent call last):
  File ".\stack15.py", line 16, in create_api
    api.verify_credentials()
  File "C:\Users\xxxxxxx\source\repos\PyProjects\py_3.7\lib\site-packages\tweepy\api.py", line 605, in verify_credentials
    )(**kargs)
  File "C:\Users\xxxxxxx\source\repos\PyProjects\py_3.7\lib\site-packages\tweepy\binder.py", line 250, in _call
    return method.execute()
  File "C:\Users\xxxxxxx\source\repos\PyProjects\py_3.7\lib\site-packages\tweepy\binder.py", line 233, in execute
    raise TweepError(error_msg, resp, api_code=api_error_code)
tweepy.error.TweepError: [{'code': 89, 'message': 'Invalid or expired token.'}]
Traceback (most recent call last):
  File ".\stack15.py", line 52, in <module>
    main()
  File ".\stack15.py", line 44, in main
    api = create_api()
  File ".\stack15.py", line 19, in create_api
    raise e
  File ".\stack15.py", line 16, in create_api
    api.verify_credentials()
  File "C:\Users\xxxxxxx\source\repos\PyProjects\py_3.7\lib\site-packages\tweepy\api.py", line 605, in verify_credentials
    )(**kargs)
  File "C:\Users\xxxxxxx\source\repos\PyProjects\py_3.7\lib\site-packages\tweepy\binder.py", line 250, in _call
    return method.execute()
  File "C:\Users\xxxxxxx\source\repos\PyProjects\py_3.7\lib\site-packages\tweepy\binder.py", line 233, in execute
    raise TweepError(error_msg, resp, api_code=api_error_code)
tweepy.error.TweepError: [{'code': 89, 'message': 'Invalid or expired token.'}]
...