码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Apache Airflow (十二) :PythonOperator


    🏡 个人主页:IT贫道_大数据OLAP体系技术栈,Apache Doris,Clickhouse 技术-CSDN博客

     🚩 私聊博主:加入大数据技术讨论群聊,获取更多大数据资料。

     🔔 博主个人B栈地址:豹哥教你大数据的个人空间-豹哥教你大数据个人主页-哔哩哔哩视频


    PythonOperator可以调用Python函数,由于Python基本可以调用任何类型的任务,如果实在找不到合适的Operator,将任务转为Python函数,使用PythonOperator即可。

    关于PythonOperator常用参数如下,更多参数可以查看官网:airflow.operators.python — Airflow Documentation

    1. python_callable(python callable):调用的python函数
    2. op_kwargs(dict):调用python函数对应的 **args 参数,dict格式,使用参照案例。
    3. op_args(list):调用python函数对应的 *args 参数,多个封装到一个tuple中,list格式,使用参照案例。

    PythonOperator调度案例

    1. import random
    2. from datetime import datetime, timedelta
    3. from airflow import DAG
    4. from airflow.operators.python import PythonOperator
    5. # python中 *  关键字参数允许你传入0个或任意个参数,这些可变参数在函数调用时自动组装为一个tuple。
    6. # python中 ** 关键字参数允许你传入0个或任意个含参数名的参数,这些关键字参数在函数内部自动组装为一个dict。
    7. def print__hello1(*a,**b):
    8.     print(a)
    9.     print(b)
    10.     print("hello airflow1")
    11. # 返回的值只会打印到日志中
    12.     return{"sss1":"xxx1"}
    13. def print__hello2(random_base):
    14.     print(random_base)
    15.     print("hello airflow2")
    16. # 返回的值只会打印到日志中
    17.     return{"sss2":"xxx2"}
    18. default_args = {
    19.     'owner':'maliu',
    20.     'start_date':datetime(2021, 10, 1),
    21.     'retries': 1,  # 失败重试次数
    22.     'retry_delay': timedelta(minutes=5) # 失败重试间隔
    23. }
    24. dag = DAG(
    25.     dag_id = 'execute_pythoncode',
    26.     default_args=default_args,
    27.     schedule_interval=timedelta(minutes=1)
    28. )
    29. first=PythonOperator(
    30.     task_id='first',
    31.     #填写  print__hello1 方法时,不要加上“()”
    32.     python_callable=print__hello1,
    33.     # op_args 对应 print_hello1 方法中的a参数
    34.     op_args=[1,2,3,"hello","world"],
    35.     # op_kwargs 对应 print__hello1 方法中的b参数
    36.     op_kwargs={"id":"1","name":"zs","age":18},
    37.     dag = dag
    38. )
    39. second=PythonOperator(
    40.     task_id='second',
    41.     #填写  print__hello2 方法时,不要加上“()”
    42.     python_callable=print__hello2,
    43.     # random_base 参数对应 print_hello2 方法中参数“random_base”
    44.     op_kwargs={"random_base":random.randint(0,9)},
    45.     dag=dag
    46. )
    47. first >> second

  • 相关阅读:
    A30 STM32_HAL库函数 之 NAND通用驱动 -- A-- 所有函数的介绍及使用
    用 Python 编写安卓 APK之helloworld(基于BeeWare)
    上海亚商投顾:沪指缩量反弹 移动支付、大金融板块走强
    计算机视觉技术的革新:医疗领域的应用
    数据驱动农业农村现代化-国稻种芯-万祥军:谋定标准化生产
    sql语句-实体属性有集合怎么批量查询
    解决IDEA中java的system.properties乱码问题
    13-ES5和ES6基础
    谷粒商城项目
    批量处理实验接触角数据-MATLAB分析
  • 原文地址:https://blog.csdn.net/qq_32020645/article/details/134504482
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号