我需要将所有的userid放在一个变量中,用\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
}我需要类似下面这样的东西:即所有的in都由一个变量中的一行分隔。
"server_names": [
[
"root",
"root",
"root",
"root",
"root",
"root",
"root",
"root",
"root"
]敬请指教。
发布于 2019-07-04 19:07:50
flatten列表
- set_fact:
server_names: "{{ server_names|flatten }}"发布于 2019-07-04 19:11:48
如果您正在迭代的项数是静态的,我想您可以使用+运算符来附加结果
- 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的答案更好。
发布于 2019-07-04 20:00:36
结合Vladmir Botka的建议,在单个任务中获得结果。
- name: Combine all userid
set_fact:
server_names: "{{ find_result_userid.results | map(attribute='stdout_lines')|list | flatten }}"https://stackoverflow.com/questions/56886502
复制相似问题