我需要将所有用户ID放在一个变量中,并用\ n分隔。 代码如下。
- name: Retrieve the user id and instance
shell: ls -l {{item}} | grep -v total| awk '{print $3}'
register: find_result_userid
with_items:
- /tmp/log/logs/log1
- /tmp/log/logs/log2
- /tmp/log/logs/log3
- name: Combine all userid
set_fact:
server_names: "{{ find_result_userid.results | map(attribute='stdout_lines')|list }}"
输出如下。
ok: [localhost] => {
"ansible_facts": {
"server_names": [
[
"root",
"root",
"root"
],
[
"root",
"root",
"root"
],
[
"root",
"root",
"root"
]
]
},
"changed": false
}
我需要如下所示的内容:即所有ID在单个变量中用一行分隔。
"server_names": [
[
"root",
"root",
"root",
"root",
"root",
"root",
"root",
"root",
"root"
]
请告知。
答案 0 :(得分:0)
flatten列表
- set_fact:
server_names: "{{ server_names|flatten }}"
答案 1 :(得分:0)
如果要迭代的项目数是静态的,我猜想,您可以使用+运算符来附加结果
- name: Combine all userid
set_fact:
server_names: "{{ find_result_userid.results[0].stdout_lines + find_result_userid.results[1].stdout_lines + find_result_userid.results[2].stdout_lines}}"
否则,如果不是静态的,我认为Vladimir Botkas的答案会更好。
答案 2 :(得分:0)
结合弗拉德米尔·博特卡(Vladmir Botka)的建议,在单个任务中获得结果。
- name: Combine all userid
set_fact:
server_names: "{{ find_result_userid.results | map(attribute='stdout_lines')|list | flatten }}"