YoVDO

Writing production-ready ETL pipelines in Python / Pandas

Offered By: Udemy

Tags

Computer Networking Courses Git Courses Jupyter Notebooks Courses Object-oriented programming Courses Functional Programming Courses Data Engineering Courses ETL Pipelines Courses

Course Description

Overview

Learn how to write professional ETL pipelines using best practices in Python and Data Engineering.

What you'll learn:
  • How to write professional ETL pipelines in Python.
  • Steps to write production level Python code.
  • How to apply functional programming in Data Engineering.
  • How to do a proper object oriented code design.
  • How to use a meta file for job control.
  • Coding best practices for Python in ETL/Data Engineering.
  • How to implement a pipeline in Python extracting data from an AWS S3 source, transforming and loading the data to another AWS S3 target.

This course will show each step to write an ETL pipeline in Python from scratch to production using the necessary tools such as Python 3.9, Jupyter Notebook, Git and Github, Visual Studio Code, Docker and Docker Hub and the Python packages Pandas, boto3, pyyaml, awscli, jupyter, pylint, moto, coverage and the memory-profiler.

Two different approaches how to code in the Data Engineering field will be introduced and applied - functional and object oriented programming.

Best practices in developing Python code will be introduced and applied:

  • design principles

  • clean coding

  • virtual environments

  • project/folder setup

  • configuration

  • logging

  • exeption handling

  • linting

  • dependency management

  • performance tuning with profiling

  • unit testing

  • integration testing

  • dockerization


What is the goal of this course?

In the course we are going to use the Xetra dataset. Xetra stands for Exchange Electronic Trading and it is the trading platform of the Deutsche Börse Group. This dataset is derived near-time on a minute-by-minute basis from Deutsche Börse’s trading system and saved in an AWS S3 bucket available to the public for free.

The ETL Pipeline we are going to create will extract the Xetra dataset from the AWS S3 source bucket on a scheduled basis, create a report using transformations and load the transformed data to another AWS S3 target bucket.

The pipeline will be written in a way that it can be deployed easily to almost any production environment that can handle containerized applications. The production environment we are going to write the ETL pipeline for consists of a GitHub Code repository, a DockerHub Image Repository, an execution platform such as Kubernetes and an Orchestration tool such as the container-native Kubernetes workflow engine Argo Workflows or Apache Airflow.


So what can you expect in the course?

You will receive primarily practical interactive lessons where you have to code and implement the pipeline and theory lessons when needed. Furthermore you will get the python code for each lesson in the course material, the whole project on GitHub and the ready to use docker image with the application code on Docker Hub.

There will be power point slides for download for each theoretical lesson and useful links for each topic and step where you find more information and can even dive deeper.



Taught by

Jan Schwarzlose

Related Courses

Introduction to Jupyter Notebooks
A Cloud Guru
Using Python for Data Management and Reporting
A Cloud Guru
Analiza tu mercado con Python
Coursera Project Network via Coursera
Clean and analyze social media usage data with Python
Coursera Project Network via Coursera
Apprentissage automatique : déploiement de modèles à l'aide de la méthode blue/green (Français) | Machine Learning: Model Deployment Using Blue/Green Method (French)
Amazon Web Services via AWS Skill Builder