我的推特回复未显示在原始状态之后

问题描述

我制作了一个自动程序,可以在关注者使用关键字致电给我时回复他们。但是回复显示在我的帐户上。得到回复的人没有看到回复或得到通知

import tweepy
import random
import time

CONSUMER_KEY = 'xxxxx'
CONSUMER_SECRET = 'xxxxx'
ACCESS_KEY = 'xx-xx'
ACCESS_SECRET = 'xxxx'

auth = tweepy.OAuthHandler(CONSUMER_KEY,CONSUMER_SECRET)
auth.set_access_token(ACCESS_KEY,ACCESS_SECRET)
api = tweepy.API(auth,wait_on_rate_limit=True,wait_on_rate_limit_notify=True)

max_tweets = 20

list_delirio = ['coisa escrita','yes']

list_isso = ['ok','nope']

list_acabou = ['bye','see you']

delirio = random.choice(list_delirio)
isso = random.choice(list_isso)
acabou = random.choice(list_acabou)


def get_id():
    with open('ultimoid.txt','r') as f:
        ultimoid = f.read()
    return ultimoid


def salva_id(novo_ultimo_id):
    with open('ultimoid.txt','w') as f:
        f.write(str(novo_ultimo_id))


def responde():
    ultimoid = get_id()
    ids_pegos = []
    time.sleep(20)
    try:
        for tweet in tweepy.Cursor(api.mentions_timeline,since_id=ultimoid).items(max_tweets):
            ids_pegos.append(tweet.id)
            user_name = tweet.user.screen_name
            status = api.get_status(tweet.id)
            if 'frota' in status.text.lower():
                api.update_status('@' + user_name + '\n hello...',in_reply_to_status_id=tweet.id,auto_populate_reply_Metadata=True)
            elif 'hello' in status.text.lower():
                api.update_status('@' + user_name + '\n wtf!',auto_populate_reply_Metadata=True)
            elif 'delírio' in status.text.lower():
                api.update_status('@' + user_name + '\n' + delirio,auto_populate_reply_Metadata=True)
            elif 'é isso?' in status.text.lower():
                api.update_status('@' + user_name + '\n' + isso,auto_populate_reply_Metadata=True)
                time.sleep(6)
            else:
                api.update_status('@' + user_name + '\n' + acabou,auto_populate_reply_Metadata=True)
                time.sleep(6)
        salva_id(max(ids_pegos))
    except Exception:
        time.sleep(30)
        pass


if __name__ == '__main__':
    while True:
        responde()
        time.sleep(30)

我正试图了解问题所在。我已经放了

in_reply_to_status_id = tweet.id,auto_populate_reply_Metadata = True

如文档所述,但仍无法正常工作

解决方法

我找到了解决方法:

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <div class="container"> <div class="row"> <div class="MultiCarousel" data-items="1,2,3,4" data-slide="1" id="MultiCarousel" data-interval="1000"> <div class="MultiCarousel-inner"> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> </div> <div class="buttons"> <a class=" leftLst"><img src="images/left_arrow.svg" alt=""></a> <a class=" rightLst"><img src="images/right_arrow.svg" alt=""></a> </div> </div> <div class="MultiCarousel" data-items="1,4" data-slide="1" id="MultiCarousel" data-interval="1000"> <div class="MultiCarousel-inner"> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> <div class="item"> <div class="col-xl-3 pad15"> <img src="https://www.fillmurray.com/200/200" class="d-block w-100" alt="..."> <div class="onhover"><span>Certifikata per Atesimin e Kaldajes Elektrike</span></div> </div> </div> </div> <div class="buttons"> <a class=" leftLst"><img src="images/left_arrow.svg" alt=""></a> <a class=" rightLst"><img src="images/right_arrow.svg" alt=""></a> </div> </div> </div> </div>行不应该在那里。因此,每个status = api.get_status(tweet.id)应该是status.text.lower()

最重要,该代码必须使用字符串而不是ID上的整数,因此每次tweet.text.lower()停留

tweet.id_str

因此将tweet.id更改为salva_id(max(ids_pegos))