Pelo que entendi, não há uma maneira de fazer isso diretamente (pelo menos não agora). Parece algo que deve ser adicionado. Recentemente, eles adicionaram alguns recursos de 'retuíte', parece lógico adicionar isso também.
Esta é uma maneira possível de fazer isso, primeiro exemplo de dados de tweet (de status/show):
<status>
<created_at>Tue Apr 07 22:52:51 +0000 2009</created_at>
<id>1472669360</id>
<text>At least I can get your humor through tweets. RT @abdur: I don't mean this in a bad way, but genetically speaking your a cul-de-sac.</text>
<source><a href="http://www.tweetdeck.com/">TweetDeck</a></source>
<truncated>false</truncated>
<in_reply_to_status_id></in_reply_to_status_id>
<in_reply_to_user_id></in_reply_to_user_id>
<favorited>false</favorited>
<in_reply_to_screen_name></in_reply_to_screen_name>
<user>
<id>1401881</id>
...
De status/showvocê pode encontrar o id do usuário. Em seguida statuses/mentions_timeline, retornará uma lista de status para um usuário. Apenas analise esse retorno procurando uma in_reply_to_status_idcorrespondência com o tweet original id.
Vamos dizer que o usuário2 responde ao tweet do usuário1. Para descobrir isso a partir do tweet do usuário1, eu precisaria pesquisar por menções para o usuário1. Mas e no caso de eu não conseguir autenticar como user1? As menções não são acessíveis publicamente sem autenticação?
letronje
@letronje Não que eu saiba - você poderia usar a API de pesquisa para encontrar '@ user1' no tweet, mas não acho que seria tão confiável quanto usar status/mentions.
Requer que você conheça o atributo screen_name do usuário do Twitter, bem como o atributo id_str do tweet em questão. Dessa forma, você pode obter um feed de conversa arbitrário a partir do tweet de qualquer usuário:
* ATUALIZAÇÃO: Código atualizado para refletir o acesso ao objeto vs acesso à matriz:
Por que isso foi rejeitado? Funciona exatamente como afirmado e responde ao problema com precisão. Além disso, meu método difere de @vsubbotin porque você pode usar o id de qualquer Tweeter em vez do seu.
Lincolnberryiii
4
Isso é bom, mas pode consumir limites de taxa valiosos (180 por oauth). 180 tweets executados com este método ... até mais!
Mike Barwick de
8
O Twitter tem uma api não documentada chamada related_results. Ele lhe dará respostas para o id do tweet especificado. Não tenho certeza de quão confiável é como seu experimental, no entanto, esta é a mesma chamada de API que é chamada no Twitter web.
Sim. como disse mathieu, não é mais ativo. Diz {u'mensagem ': desculpe, essa página não existe', u'code ': 34}
shadab.tughlaq
7
Aqui estou compartilhando um código R simples para buscar a resposta de um tweet específico
userName = "SrBachchan"
##fetch tweets from @userName timeline
tweets = userTimeline(userName,n = 1)
## converting tweets list to DataFrame
tweets <- twListToDF(tweets)
## building queryString to fetch retweets
queryString = paste0("to:",userName)
## retrieving tweet ID for which reply is to be fetched
Id = tweets[1,"id"]
## fetching all the reply to userName
rply = searchTwitter(queryString, sinceID = Id)
rply = twListToDF(rply)
## eliminate all the reply other then reply to required tweet Id
rply = rply[!rply$replyToSID > Id,]
rply = rply[!rply$replyToSID < Id,]
rply = rply[complete.cases(rply[,"replyToSID"]),]
## now rply DataFrame contains all the required replies.
O gnip.com é basicamente o único lugar de terceiros para obter dados do Twitter agora.
Abraão
3
Eu implementei isso da seguinte maneira:
1) statuses / atualização retorna id do último status (se include_entities for verdadeiro) 2) Então você pode solicitar status / menções e filtrar o resultado por in_reply_to_status_id. Este último deve ser igual ao id específico da etapa 1
Esta classe deve fazer exatamente o que você deseja. Ele raspa o HTML do site móvel e analisa uma conversa. Eu o usei por um tempo e parece muito confiável.
Não tenho certeza, não verifiquei, avisarei se encontrar algo.
pouria babvey
1
uma vez que statuses / mentions_timeline retornará as 20 menções mais recentes, não será tão eficiente chamar, e tem limitações como 75 solicitações por janela (15min), em vez disso, podemos usar user_timeline
(screen_name == nome que obtivemos em status / show)
(contagem == 1 até no máximo 200)
contagem: Especifica o número de Tweets para tentar e recuperar, até um máximo de 200 por solicitação distinta.
do resultado Apenas analise esse retorno procurando por um in_reply_to_status_id que corresponda ao id do tweet original.
Respostas:
Pelo que entendi, não há uma maneira de fazer isso diretamente (pelo menos não agora). Parece algo que deve ser adicionado. Recentemente, eles adicionaram alguns recursos de 'retuíte', parece lógico adicionar isso também.
Esta é uma maneira possível de fazer isso, primeiro exemplo de dados de tweet (de
status/show
):De
status/show
você pode encontrar o id do usuário. Em seguidastatuses/mentions_timeline
, retornará uma lista de status para um usuário. Apenas analise esse retorno procurando umain_reply_to_status_id
correspondência com o tweet originalid
.fonte
status/mentions
.status/mentions_timeline
Aqui está o procedimento para obter as respostas para um tweet
[q="to:$tweeterusername", sinceId = $tweetId]
in_reply_to_status_id_str to $tweetid
são as respostas para a postagem.fonte
Aqui está minha solução. Ele utiliza a biblioteca de PHP Oauth do Twitter de Abraham: https://github.com/abraham/twitteroauth
Requer que você conheça o atributo screen_name do usuário do Twitter, bem como o atributo id_str do tweet em questão. Dessa forma, você pode obter um feed de conversa arbitrário a partir do tweet de qualquer usuário:
* ATUALIZAÇÃO: Código atualizado para refletir o acesso ao objeto vs acesso à matriz:
fonte
O Twitter tem uma api não documentada chamada related_results. Ele lhe dará respostas para o id do tweet especificado. Não tenho certeza de quão confiável é como seu experimental, no entanto, esta é a mesma chamada de API que é chamada no Twitter web.
Use por sua conta e risco. :)
Para obter mais informações, verifique esta discussão em dev.twitter: https://dev.twitter.com/discussions/293
fonte
Aqui estou compartilhando um código R simples para buscar a resposta de um tweet específico
fonte
Não de uma maneira fácil e pragmática. Há uma solicitação de recurso para ele:
http://code.google.com/p/twitter-api/issues/detail?id=142
Existem alguns sites de terceiros que fornecem APIs, mas eles geralmente perdem o status.
fonte
Eu implementei isso da seguinte maneira:
1) statuses / atualização retorna id do último status (se include_entities for verdadeiro) 2) Então você pode solicitar status / menções e filtrar o resultado por in_reply_to_status_id. Este último deve ser igual ao id específico da etapa 1
fonte
Como afirma satheesh funciona muito bem. Aqui está o código da API REST que usei
fonte
Eu me deparei com o mesmo problema há alguns meses no trabalho, já que estava usando o
related_tweets
endpoint no REST V1.Então eu tive que criar uma solução alternativa, que documentei aqui:
http://adriancrepaz.com/twitter_conversations_apiMirror - Github forkEsta classe deve fazer exatamente o que você deseja. Ele raspa o HTML do site móvel e analisa uma conversa. Eu o usei por um tempo e parece muito confiável.
Para buscar uma conversa ...
Solicitação
Resposta
fonte
Você pode usar o pacote twarc em python para coletar todas as respostas a um tweet.
twarc replies 824077910927691778 > replies.jsonl
Além disso, é possível coletar todas as cadeias de respostas (respostas às respostas) para um tweet usando o comando abaixo:
twarc replies 824077910927691778 --recursive
fonte
uma vez que statuses / mentions_timeline retornará as 20 menções mais recentes, não será tão eficiente chamar, e tem limitações como 75 solicitações por janela (15min), em vez disso, podemos usar user_timeline
a melhor maneira: 1. obter os parâmetros screen_name ou user_id de status / show.
2. agora use user_timeline
GET https://api.twitter.com/1.1/statuses/user_timeline.json?screen_name=screen_name&count=count
(screen_name == nome que obtivemos em status / show)
(contagem == 1 até no máximo 200)
contagem: Especifica o número de Tweets para tentar e recuperar, até um máximo de 200 por solicitação distinta.
do resultado Apenas analise esse retorno procurando por um in_reply_to_status_id que corresponda ao id do tweet original.
Obviamente, não é o ideal, mas funcionará.
fonte