AnsiblePilot — Master Ansible Automation

AnsiblePilot is the leading resource for learning Ansible automation, DevOps, and infrastructure as code. Browse over 1,400 tutorials covering Ansible modules, playbooks, roles, collections, and real-world examples. Whether you are a beginner or an experienced engineer, our step-by-step guides help you automate Linux, Windows, cloud, containers, and network infrastructure.

Popular Topics

About Luca Berton

Luca Berton is an Ansible automation expert, author of 8 Ansible books published by Apress and Leanpub including "Ansible for VMware by Examples" and "Ansible for Kubernetes by Example", and creator of the Ansible Pilot YouTube channel. He shares practical automation knowledge through tutorials, books, and video courses to help IT professionals and DevOps engineers master infrastructure automation.

Verify File Existence on Windows with Ansible

By Luca Berton · Published 2024-01-01 · Category: troubleshooting

Discover how to check if a file exists on Windows systems with Ansible's win_stat module. This guide includes a live Playbook example and execution details.

Verify File Existence on Windows with Ansible

How to Check if a file exists on Windows-like systems with Ansible?

I'm going to show you a live Playbook and some simple Ansible code. I'm Luca Berton and welcome to today's episode of Ansible Pilot.

See also: Ansible win_file Module: Create Directory on Windows Hosts (Guide)

Ansible check file exists on Windows-like systems

ansible.windows.win_stat • Get information about Windows files

Today we're talking about the Ansible module win_stat. The full name is ansible.windows.win_stat, which means that is part of the collection of modules specialized to interact with Windows target host. It's a module pretty stable and out for years. It works in Windows and Windows Server operating systems. It gets information about Windows files. For Linux target use the ansible.builtin.stat module instead.

Parameters & Return Values

Mandatory Parameters

• path string

Main Return Values

• stat complex - exists

The only mandatory parameter is "path" which is the filesystem full path of the object to check. You could also retrieve the checksum of the file in the most popular hash algorithm, just in case. The module returns a complex object, the property that is interesting for us is "exists". This attribute is "true" if the object exists.

See also: Ansible win_file Module: Create & Manage Files on Windows (Guide)

Links

ansible.windows.win_stat

## Playbook

How to check if the file "example.txt" exists on the Desktop of the user on Windows-like systems with Ansible Playbook.

code

---
- name: check if a file exist
  hosts: all
  vars:
    myfile: 'C:\Users\vagrant\Desktop\example.txt'
  tasks:
    - name: check if a file exist
      ansible.windows.win_stat:
        path: "{{ myfile }}"
      register: file_data
    - name: report file exist
      ansible.builtin.debug:
        msg: "The file {{ myfile }} exist"
      when: file_data.stat.exists
    - name: report file not exist
      ansible.builtin.debug:
        msg: "The file {{ myfile }} doesn't exist"
      when: not file_data.stat.exists

file doesn't exist execution

win_stat file doesn't exist
ansible-pilot $ ansible-playbook -i virtualmachines/win/inventory check\ file\ exists/file_exist_windows.yml
PLAY [check if a file exist] **********************************************************************
TASK [Gathering Facts] ****************************************************************************
ok: [WindowsServer]
TASK [check if a file exist] **********************************************************************
ok: [WindowsServer]
TASK [report file exist] **************************************************************************
skipping: [WindowsServer]
TASK [report file not exist] **********************************************************************
ok: [WindowsServer] => {
    "msg": "The file C:\\Users\\vagrant\\Desktop\\example.txt doesn't exist"
}
PLAY RECAP ****************************************************************************************
WindowsServer              : ok=3    changed=0    unreachable=0    failed=0    skipped=1    rescued=0    ignored=0
ansible-pilot $

file exist execution

win_stat file exist
ansible-pilot $ ansible-playbook -i virtualmachines/win/inventory check\ file\ exists/file_exist_windows.yml
PLAY [check if a file exist] **********************************************************************
TASK [Gathering Facts] ****************************************************************************
ok: [WindowsServer]
TASK [check if a file exist] **********************************************************************
ok: [WindowsServer]
TASK [report file exist] **************************************************************************
ok: [WindowsServer] => {
    "msg": "The file C:\\Users\\vagrant\\Desktop\\example.txt exist"
}
TASK [report file not exist] **********************************************************************
skipping: [WindowsServer]
PLAY RECAP ****************************************************************************************
WindowsServer              : ok=3    changed=0    unreachable=0    failed=0    skipped=1    rescued=0    ignored=0
ansible-pilot $

code with ❤️ in GitHub

Conclusion

Now you know how to check if a file exists on Windows-like systems with Ansible.

See also: Ansible win_unzip Module: Extract ZIP Archives on Windows (Guide)

Related Articles

conditional execution with Ansible whenmanaging inventory in Ansiblemanaging Windows hosts with Ansible

Category: troubleshooting

Watch the video: Verify File Existence on Windows with Ansible — Video Tutorial

Browse all Ansible tutorials · AnsiblePilot Home