【发布时间】:2021-08-17 17:00:58
【问题描述】:
我有一个气流操作符,它返回一个字符串值,任务名为“task1”。所以执行后我进入 xcom 并检查 return_value 和它只是一个字符串(下面的屏幕截图)。
然后我有一个名为 task2 的运算符从 task1 的 xcom 值中获取输入,如下所示:
"{{ ti.xcom_pull(task_ids=['task1'],key='return_value')}}"
问题是它得到的值是一个转换为字符串的列表。
xcom 中的值:这只是一个字符串
xcom pull(jinga 模板版本)返回的值:['this is just a string']
那么有没有办法可以更新上面显示的 xcom pull(jinga 版本)来拉取值?我无法在运算符内部访问它被传递的内容,或者我可以放置一些逻辑将字符串转换为列表,然后仅获取值(但这并不理想,也不是一个选项)。
另外,我认为它的工作提到我尝试做类似的事情,但使用 Python 运算符然后使用 python 代码中的内容执行 xcom pull 并且返回值很好。所以我不确定为什么 xcom pull 使用 Jinja 模板会这样做,我该如何解决这个问题?我希望我可以做一些我不知道的事情来轻松获得我想要的输出。工作的python操作符代码如下(仅供参考...)
def python_code_task3(**context):
value = context['ti'].xcom_pull(task_ids='task1', key='return_value')
logging.info("Value: " + value)
这段代码只是输出我想要的值这只是一个字符串
我真的只想使用jinga模板版本并让它检索并传入字符串。不是将字符串值作为列表中的一项的列表的字符串表示形式。
【问题讨论】:
标签: airflow