Solucionado (ver solução)
Solucionado
(ver solução)
3
respostas

ERRO ao chamar recent_serch.py

Quando tento chamar o recent_search.py com o comando: python3 recent_search.py

seguinte erro aparece:

400 Traceback (most recent call last): File "recent_search.py", line 63, in main() File "recent_search.py", line 58, in main for json_response in paginate(url, headers): File "recent_search.py", line 49, in paginate data = connect_to_endpoint(full_url, headers) File "recent_search.py", line 40, in connect_to_endpoint raise Exception(response.status_code, response.text) Exception: (400, '{"errors":[{"parameters":{"start_time":["2021-02-15T00:00Z"]},"message":"Invalid 'start_time':'2021-02-15T00:00Z'. 'start_time' must be on or after 2021-10-27T19:52Z"},{"parameters":{"end_time":["2021-02-19T00:00Z"]},"message":"Invalid 'end_time':'2021-02-19T00:00Z'. 'end_time' must be on or after 2021-10-27T19:52Z"}],"title":"Invalid Request","detail":"One or more parameters to your request was invalid.","type":"https://api.twitter.com/2/problems/invalid-request"}')

3 respostas

Arquivo recent_search usado:

CODIGO:

import requests
import os
import json

# To set your enviornment variables in your terminal run the following line:
# export 'BEARER_TOKEN'='<your_bearer_token>'


def auth():
    return os.environ.get("BEARER_TOKEN")


def create_url():
    query = "AluraOnline"
    # Tweet fields are adjustable.
    # Options include:
    # attachments, author_id, context_annotations,
    # conversation_id, created_at, entities, geo, id,
    # in_reply_to_user_id, lang, non_public_metrics, organic_metrics,
    # possibly_sensitive, promoted_metrics, public_metrics, referenced_tweets,
    # source, text, and withheld
    tweet_fields = "tweet.fields=author_id,conversation_id,created_at,id,in_reply_to_user_id,public_metrics,text"
    user_fields = "expansions=author_id&user.fields=id,name,username,created_at"
    filters = "start_time=2021-02-15T00:00:00.00Z&end_time=2021-02-19T00:00:00.00Z"
    url = "https://api.twitter.com/2/tweets/search/recent?query={}&{}&{}&{}".format(
        query, tweet_fields, user_fields, filters
    )
    return url


def create_headers(bearer_token):
    headers = {"Authorization": "Bearer {}".format(bearer_token)}
    return headers


def connect_to_endpoint(url, headers):
    response = requests.request("GET", url, headers=headers)
    print(response.status_code)
    if response.status_code != 200:
        raise Exception(response.status_code, response.text)
    return response.json()


def paginate(url, headers, next_token=""):
    if next_token:
        full_url = f"{url}&next_token={next_token}"
    else:
        full_url = url
    data = connect_to_endpoint(full_url, headers)
    yield data
    if "next_token" in data.get("meta", {}):
        yield from paginate(url, headers, data['meta']['next_token'])

def main():
    bearer_token = auth()
    url = create_url()
    headers = create_headers(bearer_token)
    for json_response in paginate(url, headers):
        print(json.dumps(json_response, indent=4, sort_keys=True))


if __name__ == "__main__":
    main()
solução!

Boa noite lucas, tudo bem?

O erro me parece ser relacionado ao start_time.

Se não me engano, a API do Twitter so retorna os dados de ate 7 dias antes do atual. então tenta mudar a data do start_time pra 4 dias antes do dia da busca e o end_time com a data do dia atual.

Qualquer coisa informa se deu certo.

Bah, que vacilo, revi a aula e o professor fala exatamente isto. Muito obrigado Melquesedeque Balbino!!! Deu certo agora, falta de atenção minha.