Airflow“3分钟上手”教程:用Python定义定时数据清洗任务

一、第1步:快速安装Airflow(1分钟)

Docker一键部署(推荐)

复制代码
bash

# 克隆官方项目(含Docker配置) git clone https://gitcode.com/GitHub_Trending/ai/airflow cd GitHub_Trending/ai/airflow # 启动开发环境(自动安装依赖) ./breeze start-airflow

验证 :访问 http://localhost:8080,默认账号密码均为 airflow

---

二、第2步:写Python数据清洗DAG(1分钟)

创建DAG文件

airflow/dags 目录下新建 datacleaning_dag.py

复制代码
python

from airflow import DAG from airflow.operators.python import PythonOperator from datetime import datetime, timedelta import pandas as pd # 1. 定义数据清洗函数 def clean_data(): # 读取原始数据(假设本地有raw_data.csv) df = pd.read_csv('/opt/airflow/dags/raw_data.csv') # 清洗逻辑:去重、删空值 df = df.drop_duplicates().dropna().reset_index(drop=True) # 保存清洗后数据 df.to_csv('/opt/airflow/dags/cleaned_data.csv', index=False) # 2. 定义DAG(定时任务流程) with DAG( dag_id='daily_data_cleaning', # DAG名称 start_date=datetime(2023, 1, 1), # 开始日期 schedule_interval='@daily', # 调度频率:每天执行 catchup=False # 不回溯执行历史任务 ) as dag: # 3. 创建任务(调用Python函数) clean_task = PythonOperator( task_id='clean_data_task', # 任务ID python_callable=clean_data # 绑定清洗函数 ) # 4. 设置任务依赖(单任务无需依赖,多任务用 >> 连接) clean_task

三、第3步:启动调度与监控(1分钟)

1. 启动Airflow服务
复制代码
bash

# 启动Web服务器(后台运行) airflow webserver -D -p 8080 # 启动调度器(处理定时任务) airflow scheduler -D

2. 在Web界面监控任务

访问 http://localhost:8080,在DAG列表中找到 daily_data_cleaning,点击 ▶️ 启动。

  • 状态说明:绿色表示成功,红色表示失败,点击任务可查看日志(如数据路径错误、依赖缺失等)。

关键说明 智优达

  • 调度频率schedule_interval 支持 cron 表达式(如 0 8 * * * 每天8点执行)或预设值(@hourly 每小时、@weekly 每周)。
  • 文件路径 :Airflow容器内路径需挂载本地目录(如 -v /本地数据目录:/opt/airflow/dags),确保能读取 raw_data.csv
相关推荐
汗流浃背了吧,老弟!6 分钟前
BPE 词表构建与编解码(英雄联盟-托儿索语料)
人工智能·深度学习
软件聚导航14 分钟前
从 AI 画马到马年红包封面,我还做了一个小程序
人工智能·chatgpt
JQLvopkk21 分钟前
C# 轻量级工业温湿度监控系统(含数据库与源码)
开发语言·数据库·c#
啊森要自信30 分钟前
CANN ops-cv:AI 硬件端视觉算法推理训练的算子性能调优与实战应用详解
人工智能·算法·cann
要加油哦~33 分钟前
AI | 实践教程 - ScreenCoder | 多agents前端代码生成
前端·javascript·人工智能
玄同76534 分钟前
从 0 到 1:用 Python 开发 MCP 工具,让 AI 智能体拥有 “超能力”
开发语言·人工智能·python·agent·ai编程·mcp·trae
czy878747536 分钟前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
新缸中之脑36 分钟前
用RedisVL构建长期记忆
人工智能
消失的旧时光-194340 分钟前
从 Kotlin 到 Dart:为什么 sealed 是处理「多种返回结果」的最佳方式?
android·开发语言·flutter·架构·kotlin·sealed
yq19820430115641 分钟前
静思书屋:基于Java Web技术栈构建高性能图书信息平台实践
java·开发语言·前端