1
resposta

Conectando ao Twitter - Erro ao montar Funcao de paginar

Olá bom dia,

Ao tentar execurr o arquivo, tentei trocar as datas e parametros informados mais sem sucesso!

erro a baixo:

400 Traceback (most recent call last): File "recent_search.py", line 65, in main() File "recent_search.py", line 60, in main for json_response in paginate(url, headers): File "recent_search.py", line 51, in paginate data = connect_to_endpoint(full_url, headers) File "recent_search.py", line 42, 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-09-13T14:52Z"},{"parameters":{"end_time":["2021-02-19T00:00Z"]},"message":"Invalid 'end_time':'2021-02-19T00:00Z'. 'end_time' must be on or after 2021-09-13T14:52Z"}],"title":"Invalid Request","detail":"One or more parameters to your request was invalid.","type":"https://api.twitter.com/2/problems/invalid-request"}')

Logo a baixo se encontra meu codigo que to acompanhando pelo video

import requests import os import json

To set your enviornment variables in your terminal run the following line:

export '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
##usando API p/buscar informacoes pontuais
tweet_fields = "tweet.fields=author_id,conversation_id,created_at,id,in_reply_to_user_id,public_metrics,text"
##expandido os usuarios, autor, id, quando foi criado
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()

#####metodo de paginacao 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()

1 resposta

Ola Marcos, O script roda para um periodo dentro dos ultimos 7 dias, na mensagem de erro esta dizendo que a data precisa ser depois do dia 2021-09-13.

Quer mergulhar em tecnologia e aprendizagem?

Receba a newsletter que o nosso CEO escreve pessoalmente, com insights do mercado de trabalho, ciência e desenvolvimento de software