File Ansible-从远程计算机上的文件中获取密钥对值并填充变量

File Ansible-从远程计算机上的文件中获取密钥对值并填充变量,file,dictionary,ansible,cat,File,Dictionary,Ansible,Cat,尝试从.yaml文件中提取密钥对值并将其填充到变量中: /etc/puppetlabs/puppet/csr_attributes.yaml 文件示例: extension_requests: pp_service: 'private' pp_instance_id: 'blah' pp_image_name: 'RedHat 7.7 Base' pp_project: 'TBT' pp_application: 'xxxxx' pp_environment: '

尝试从.yaml文件中提取密钥对值并将其填充到变量中:

/etc/puppetlabs/puppet/csr_attributes.yaml

文件示例:

extension_requests:
  pp_service: 'private'
  pp_instance_id:  'blah'
  pp_image_name:  'RedHat 7.7 Base'
  pp_project:  'TBT'
  pp_application:  'xxxxx'
  pp_environment: 'dev'
  pp_role: 'base_stuff'
  pp_software_version: '2020-04-30'
  pp_provisioner: 'Ansible Tower'
  pp_datacenter: 'DC2'
  pp_zone: 'C6600_NPE_RS'
  pp_cloudplatform: 'esx'
  pp_apptier: 'dev'
  pp_securitypolicy: 'Stuff'
  1.3.6.1.4.1.34380.1.2.1:  ''
  1.3.6.1.4.1.34380.1.2.2:  '8'
  1.3.6.1.4.1.34380.1.2.3:  '77504'
我可以通过行号进行操作,但我需要更具动态性,因为不同服务器的行号不同:

当前单行代码:

- name: cat file
  shell: cat /etc/puppetlabs/puppet/csr_attributes.yaml
  register: cat_content_file

- set_fact:
    pp_service: "pp_service: {{ cat_content_file.stdout_lines[2].split()[1] }}"
    pp_application: "pp_application: {{ cat_content_file.stdout_lines[6].split()[1] }}"

- debug:
    msg:
    - "{{ pp_service }}"
    - "{{ pp_application }}"
我想我需要将输出转换成dict,但我完全被困在如何实现这一点上。
任何建议都将不胜感激。

您可以结合使用和:

  - set_fact:
      your_variable: "{{ lookup('file','/etc/puppetlabs/puppet/csr_attributes.yaml') | from_yaml }}"
  - debug: var=your_variable.extension_requests.pp_service