首页 > 编程语言 >kettle从入门到精通 第六十三课 ETL之kettle kettle调用python脚本的两种方法

kettle从入门到精通 第六十三课 ETL之kettle kettle调用python脚本的两种方法

时间:2024-05-25 11:08:59浏览次数:24  
标签:脚本 __ shell python kettle 调用 第六十三

kettle中不能直接调用python脚本,可以通过shell脚本和http进行调用pyton服务。

一、shell脚本调用python脚本

1、下面是一段简单的无参python脚本

import os

def main():
    # 在这里编写Python脚本的主要逻辑
    print("Hello, this is a Python script called by shell!")

if __name__ == "__main__":
    main()

2、通过shell脚本调用。

 shell脚本

cd D:\king\kettle-demo
py test.py

 3、将步骤【Shell】拉入画布,步骤内直接编写shell脚本或者调用shell文件进行调用python脚本,如下图所示:

 4、采用直接插入shell脚本的方式调用python脚本,如下图所示:

 5、选项卡脚本文本框内直接填写shell脚本,如下图所示:

6、下面是一段简单的带参python脚本

# 文件名:script_with_args.py

import sys

def main():
    if len(sys.argv) < 2:
        print("Usage: python script_with_args.py <arg1>")
        return
    
    arg1 = sys.argv[1]
    print(f"Argument passed from shell: {arg1}")

if __name__ == "__main__":
    main()

7、采用py test1.py java命令将参数java传递给python脚本,如下图所示:

 8、采用调用shell文件(rundemo.bat或者rundemo.sh)方式进而调用python脚本,如下图所示:

最下面的参数可以设置传递给python脚本参数,如设置V1参数。

 

9、采用调用shell文件(rundemo.bat或者rundemo.sh)方式进而调用python脚本,如下图所示:

也可以上一步骤的结果作为参数传递给python脚本。

 10、转换中设置一个参数V1为java,然后将java字符串传递给python脚本,如下图所示:

 二、http方式调用pyton服务

此处是将python脚本暴露http服务接口,然后在kettle中使用http步骤进行调用。这里不在详细介绍,可以参考之前的http调用文章。至于python脚本如何暴露http服务(使用Flask轻松解决),如下图所示:

 

标签:脚本,__,shell,python,kettle,调用,第六十三
From: https://www.cnblogs.com/zjBoy/p/18208371

相关文章

  • Python中的异常处理:try, except, else, finally详解
    Python中的异常处理:try,except,else,finally详解在Python编程中,异常处理是确保程序健壮性和错误处理能力的重要机制。通过使用try,except,else,finally等关键字,Python提供了灵活的异常处理框架,使得开发者能够优雅地处理运行时错误和其他异常情况。本文将详细解析这些......
  • Python中别再用 ‘+‘ 拼接字符串了!
    大家好,在Python编程中,我们常常需要对字符串进行拼接。你可能会自然地想到用+操作符将字符串连接起来,毕竟这看起来简单明了。在Python中,字符串是不可变的数据类型,这意味着一旦字符串被创建,它就不能被修改。因此,当你尝试通过使用+来连接字符串时,实际上Python会创建......
  • Python异步编程之基础概念
    Python异步编程之基础概念在现代编程中,异步编程是一种重要的技术,尤其是在处理I/O密集型任务时,异步编程可以大大提高程序的性能和响应速度。本文将介绍Python异步编程的基础概念,帮助你理解其原理和应用。什么是异步编程?异步编程是一种并发编程模型,它允许程序在等待某些任......
  • SpringCloud + Python 混合微服务架构,打造AI分布式业务应用的技术底层
    文章很长,且持续更新,建议收藏起来,慢慢读!疯狂创客圈总目录博客园版为您奉上珍贵的学习资源:免费赠送:《尼恩Java面试宝典》持续更新+史上最全+面试必备2000页+面试必备+大厂必备+涨薪必备免费赠送:《尼恩技术圣经+高并发系列PDF》,帮你实现技术自由,完成职业升级,薪......
  • 深入解析Python并发的多线程和异步编程
    在Python编程中,多线程是一种常用的并发编程方式,它可以有效地提高程序的执行效率,特别是在处理I/O密集型任务时。Python提供了threading模块,使得多线程编程变得相对简单。本文将深入探讨threading模块的基础知识,并通过实例演示多线程的应用。1.多线程基础概念在开始之前,让我们......
  • 计算机毕业设计python+spark天气预测 天气可视化 天气大数据 空气质量检测 空气质量分
    摘  要近些年大数据人工智能等技术发展迅速,我国工业正努力从“制造”迈向“智造”实现新跨越。神经网络(NeuronNetwork)是一种计算模型,通过大量数据的学习,来发现数据之间的模式和规律,模仿人脑神经元的工作方式。随着算力的提升和算法的不断成熟图像识别技术已经完全融入到生......
  • python print 追加写入文件
    在Python中,要使用print函数将内容追加写入到文件而不是覆盖原有内容,你需要在打开文件时使用追加模式'a'。以下是一个示例:pythonwithopen('output.txt','a')asfile:print("这是追加到文件的内容",file=file)在这个例子中:open('output.txt','a')以追加模式('a�......
  • 卷积神经网路的原理及Python实现
    卷积神经网络(ConvolutionalNeuralNetworks)是一种深度学习模型或类似于人工神经网络的多层感知器,常用来分析视觉图像。卷积神经网络(ConvolutionalNeuralNetwork,CNN)是一种在计算机视觉领域取得了巨大成功的深度学习模型,该算法的灵感来自于人脑的一部分,即视觉皮层。视觉皮层是人......
  • python核心编程
    python核心编程一、python函数1.1函数的概念1.2函数的基本使用1.3函数的参数1.3.1单个参数1.3.2多个参数1.3.3不定长参数1.3.4缺省参数1.3.5参数注意1.4函数的返回值1.5函数的使用描述1.6函数的作用域1.7相关函数1.7.1偏函数1.7.2高阶函数1.7.3返回函数1......
  • python基础 - 文件的读写和yaml文件读取
    读取文件读取文件用withopen(文件路径,读写模式)r读(默认值),w写,a追加写#读文件的几种方式:1、read()返回文件内容,返回的是字符串filepath='D:/note1.txt'withopen(filepath,'r')asf:print(f.read())2、readLine()返回文件一行的内容,返回的是字符串withopen(filepath,'r')as......