Agendando jobs diários

Introdução à Engenharia de Dados

Vincent Vankrunkelsven

Data Engineer @ DataCamp

O que você fez até agora

 

  • Extrair com extract_course_data() e extract_rating_data()
  • Limpar NAs com transform_fill_programming_language()
  • Média de avaliações por curso: transform_avg_rating()
  • Pares elegíveis de usuário e curso: transform_courses_to_recommend()
  • Calcular recomendações: transform_recommendations()
Introdução à Engenharia de Dados

Carregando no Postgres

 

  • Usar os cálculos em produtos de dados
  • Atualizar diariamente
  • Exemplo: enviar e-mails com recomendações
Introdução à Engenharia de Dados

A fase de carga

 

recommendations.to_sql(
    "recommendations",
    db_engine,
    if_exists="append",
)
Introdução à Engenharia de Dados
def etl(db_engines):
    # Extract the data
    courses = extract_course_data(db_engines)
    rating = extract_rating_data(db_engines)
    # Clean up courses data
    courses = transform_fill_programming_language(courses)

# Get the average course ratings avg_course_rating = transform_avg_rating(rating)
# Get eligible user and course id pairs courses_to_recommend = transform_courses_to_recommend( rating, courses, )
# Calculate the recommendations recommendations = transform_recommendations( avg_course_rating, courses_to_recommend, )
# Load the recommendations into the database load_to_dwh(recommendations, db_engine))
Introdução à Engenharia de Dados

Criando o DAG

from airflow.models import DAG
from airflow.operators.python_operator import PythonOperator

dag = DAG(dag_id="recommendations",
          scheduled_interval="0 0 * * *")

task_recommendations = PythonOperator( task_id="recommendations_task", python_callable=etl, )
Introdução à Engenharia de Dados

Vamos praticar!

Introdução à Engenharia de Dados

Preparing Video For Download...