Skip to main content

Filesystem events monitoring

Project description

Build Status CirrusCI Status

Python API and shell utilities to monitor file system events.

Works on 3.6+.

If you want to use Python 2.6, you should stick with watchdog < 0.10.0.

If you want to use Python 2.7, 3.4 or 3.5, you should stick with watchdog < 1.0.0.

Example API Usage

A simple program that uses watchdog to monitor directories specified as command-line arguments and logs events generated:

import sys
import time
import logging
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler

if __name__ == "__main__":
    logging.basicConfig(level=logging.INFO,
                        format='%(asctime)s - %(message)s',
                        datefmt='%Y-%m-%d %H:%M:%S')
    path = sys.argv[1] if len(sys.argv) > 1 else '.'
    event_handler = LoggingEventHandler()
    observer = Observer()
    observer.schedule(event_handler, path, recursive=True)
    observer.start()
    try:
        while True:
            time.sleep(1)
    finally:
        observer.stop()
        observer.join()

Shell Utilities

Watchdog comes with an optional utility script called watchmedo. Please type watchmedo --help at the shell prompt to know more about this tool.

Here is how you can log the current directory recursively for events related only to *.py and *.txt files while ignoring all directory events:

watchmedo log \
    --patterns="*.py;*.txt" \
    --ignore-directories \
    --recursive \
    .

You can use the shell-command subcommand to execute shell commands in response to events:

watchmedo shell-command \
    --patterns="*.py;*.txt" \
    --recursive \
    --command='echo "${watch_src_path}"' \
    .

Please see the help information for these commands by typing:

watchmedo [command] --help

About watchmedo Tricks

watchmedo can read tricks.yaml files and execute tricks within them in response to file system events. Tricks are actually event handlers that subclass watchdog.tricks.Trick and are written by plugin authors. Trick classes are augmented with a few additional features that regular event handlers don’t need.

An example tricks.yaml file:

tricks:
- watchdog.tricks.LoggerTrick:
    patterns: ["*.py", "*.js"]
- watchmedo_webtricks.GoogleClosureTrick:
    patterns: ['*.js']
    hash_names: true
    mappings_format: json                  # json|yaml|python
    mappings_module: app/javascript_mappings
    suffix: .min.js
    compilation_level: advanced            # simple|advanced
    source_directory: app/static/js/
    destination_directory: app/public/js/
    files:
      index-page:
      - app/static/js/vendor/jquery*.js
      - app/static/js/base.js
      - app/static/js/index-page.js
      about-page:
      - app/static/js/vendor/jquery*.js
      - app/static/js/base.js
      - app/static/js/about-page/**/*.js

The directory containing the tricks.yaml file will be monitored. Each trick class is initialized with its corresponding keys in the tricks.yaml file as arguments and events are fed to an instance of this class as they arrive.

Installation

Install from PyPI using pip:

$ python -m pip install -U watchdog

# or to install the watchmedo utility:
$ python -m pip install -U "watchdog[watchmedo]"

Install from source:

$ python -m pip install -e .

# or to install the watchmedo utility:
$ python -m pip install -e ".[watchmedo]"

Installation Caveats

The watchmedo script depends on PyYAML which links with LibYAML, which brings a performance boost to the PyYAML parser. However, installing LibYAML is optional but recommended. On macOS, you can use homebrew to install LibYAML:

$ brew install libyaml

On Linux, use your favorite package manager to install LibYAML. Here’s how you do it on Ubuntu:

$ sudo apt install libyaml-dev

On Windows, please install PyYAML using the binaries they provide.

Documentation

You can browse the latest release documentation online.

Contribute

Fork the repository on GitHub and send a pull request, or file an issue ticket at the issue tracker. For general help and questions use the official mailing list or ask on stackoverflow with tag python-watchdog.

Create and activate your virtual environment, then:

python -m pip install pytest pytest-cov
python -m pip install -e ".[watchmedo]"
python -m pytest tests

If you are making a substantial change, add an entry to the “Unreleased” section of the changelog.

Supported Platforms

  • Linux 2.6 (inotify)

  • macOS (FSEvents, kqueue)

  • FreeBSD/BSD (kqueue)

  • Windows (ReadDirectoryChangesW with I/O completion ports; ReadDirectoryChangesW worker threads)

  • OS-independent (polling the disk for directory snapshots and comparing them periodically; slow and not recommended)

Note that when using watchdog with kqueue, you need the number of file descriptors allowed to be opened by programs running on your system to be increased to more than the number of files that you will be monitoring. The easiest way to do that is to edit your ~/.profile file and add a line similar to:

ulimit -n 1024

This is an inherent problem with kqueue because it uses file descriptors to monitor files. That plus the enormous amount of bookkeeping that watchdog needs to do in order to monitor file descriptors just makes this a painful way to monitor files and directories. In essence, kqueue is not a very scalable way to monitor a deeply nested directory of files and directories with a large number of files.

About using watchdog with editors like Vim

Vim does not modify files unless directed to do so. It creates backup files and then swaps them in to replace the files you are editing on the disk. This means that if you use Vim to edit your files, the on-modified events for those files will not be triggered by watchdog. You may need to configure Vim appropriately to disable this feature.

About using watchdog with CIFS

When you want to watch changes in CIFS, you need to explicitly tell watchdog to use PollingObserver, that is, instead of letting watchdog decide an appropriate observer like in the example above, do:

from watchdog.observers.polling import PollingObserver as Observer

Dependencies

  1. Python 3.6 or above.

  2. XCode (only on macOS when installing from sources)

  3. PyYAML (only for watchmedo)

Licensing

Watchdog is licensed under the terms of the Apache License, version 2.0.

Copyright 2011 Yesudeep Mangalapilly.

Copyright 2012 Google, Inc & contributors.

Project source code is available at Github. Please report bugs and file enhancement requests at the issue tracker.

Why Watchdog?

Too many people tried to do the same thing and none did what I needed Python to do:

Changelog

2.1.8

2022-05-15 • full history

  • Fix adding failed emitters on observer schedule. (#872)

  • [inotify] Fix hang when unscheduling watch on a path in an unmounted filesystem. (#869)

  • [watchmedo] Fix broken parsing of --kill-after argument for the auto-restart command. (#870)

  • [watchmedo] Fix broken parsing of boolean arguments. (#887)

  • [watchmedo] Fix broken parsing of commands from auto-restart, and shell-command. (#888)

  • [watchmedo] Support setting verbosity level via -q/--quiet and -v/--verbose arguments. (#889)

  • Thanks to our beloved contributors: @taleinat, @kianmeng, @palfrey, @IlayRosenberg, @BoboTiG

2.1.7

2022-03-25 • full history

  • Eliminate timeout in waiting on event queue. (#861)

  • [inotify] Fix not equality implementation for InotifyEvent. (#848)

  • [watchmedo] Fix calling commands from within a Python script. (#879)

  • [watchmedo] PyYAML is loaded only when strictly necessary. Simple usages of watchmedo are possible without the module being installed. (#847)

  • Thanks to our beloved contributors: @sattlerc, @JanzenLiu, @BoboTiG

2.1.6

2021-10-01 • full history

  • [bsd] Fixed returned paths in kqueue.py and restored the overall results of the test suite. (#842)

  • [bsd] Updated FreeBSD CI support .(#841)

  • [watchmedo] Removed the argh dependency in favor of the builtin argparse module. (#836)

  • [watchmedo] Removed unexistant WindowsApiAsyncObserver references and --debug-force-winapi-async arguments.

  • [watchmedo] Improved the help output.

  • Thanks to our beloved contributors: @knobix, @AndreaRe9, @BoboTiG

2.1.5

2021-08-23 • full history

  • Fix regression introduced in 2.1.4 (reverted “Allow overriding or adding custom event handlers to event dispatch map. (#814)”). (#830)

  • Convert regexes of type str to list. (831)

  • Thanks to our beloved contributors: @unique1o1, @BoboTiG

2.1.4

2021-08-19 • full history

  • [watchmedo] Fix usage of os.setsid() and os.killpg() Unix-only functions. (#809)

  • [mac] Fix missing FileModifiedEvent on permission or ownership changes of a file. (#815)

  • [mac] Convert absolute watch path in FSEeventsEmitter with os.path.realpath(). (#822)

  • Fix a possible AttributeError in SkipRepeatsQueue._put(). (#818)

  • Allow overriding or adding custom event handlers to event dispatch map. (#814)

  • Fix tests on big endian platforms. (#828)

  • Thanks to our beloved contributors: @replabrobin, @BoboTiG, @SamSchott, @AndreiB97, @NiklasRosenstein, @ikokollari, @mgorny

2.1.3

2021-06-26 • full history

  • Publish macOS arm64 and universal2 wheels. (#740)

  • Thanks to our beloved contributors: @kainjow, @BoboTiG

2.1.2

2021-05-19 • full history

  • [mac] Fix relative path handling for non-recursive watch. (#797)

  • [windows] On PyPy, events happening right after start() were missed. Add a workaround for that. (#796)

  • Thanks to our beloved contributors: @oprypin, @CCP-Aporia, @BoboTiG

2.1.1

2021-05-10 • full history

  • [mac] Fix callback exceptions when the watcher is deleted but still receiving events (#786)

  • Thanks to our beloved contributors: @rom1win, @BoboTiG, @CCP-Aporia

2.1.0

2021-05-04 • full history

  • [inotify] Simplify libc loading (#776)

  • [mac] Add support for non-recursive watches in FSEventsEmitter (#779)

  • [watchmedo] Add support for --debug-force-* arguments to tricks (#781)

  • Thanks to our beloved contributors: @CCP-Aporia, @aodj, @UnitedMarsupials, @BoboTiG

2.0.3

2021-04-22 • full history

  • [mac] Use logger.debug() instead of logger.info() (#774)

  • Updated documentation links (#777)

  • Thanks to our beloved contributors: @globau, @imba-tjd, @BoboTiG

2.0.2

2021-02-22 • full history

  • [mac] Add missing exception objects (#766)

  • Thanks to our beloved contributors: @CCP-Aporia, @BoboTiG

2.0.1

2021-02-17 • full history

  • [mac] Fix a segmentation fault when dealing with unicode paths (#763)

  • Moved the CI from Travis-CI to GitHub Actions (#764)

  • Thanks to our beloved contributors: @SamSchott, @BoboTiG

2.0.0

2021-02-11 • full history

  • Avoid deprecated PyEval_InitThreads on Python 3.7+ (#746)

  • [inotify] Add support for IN_CLOSE_WRITE events. A FileCloseEvent event will be fired. Note that IN_CLOSE_NOWRITE events are not handled to prevent much noise. (#184, #245, #280, #313, #690)

  • [inotify] Allow to stop the emitter multiple times (#760)

  • [mac] Support coalesced filesystem events (#734)

  • [mac] Drop support for macOS 10.12 and earlier (#750)

  • [mac] Fix an issue when renaming an item changes only the casing (#750)

  • Thanks to our beloved contributors: @bstaletic, @lukassup, @ysard, @SamSchott, @CCP-Aporia, @BoboTiG

1.0.2

2020-12-18 • full history

  • Wheels are published for GNU/Linux, macOS and Windows (#739)

  • [mac] Fix missing event_id attribute in fsevents (#721)

  • [mac] Return byte paths if a byte path was given in fsevents (#726)

  • [mac] Add compatibility with old macOS versions (#733)

  • Uniformize event for deletion of watched dir (#727)

  • Thanks to our beloved contributors: @SamSchott, @CCP-Aporia, @di, @BoboTiG

1.0.1

2020-12-10 • Fix version with good metadatas.

1.0.0

2020-12-10 • full history

  • Versioning is now following the semver

  • Drop support for Python 2.7, 3.4 and 3.5

  • [mac] Regression fixes for native fsevents (#717)

  • [windows] winapi.BUFFER_SIZE now defaults to 64000 (instead of 2048) (#700)

  • [windows] Introduced winapi.PATH_BUFFER_SIZE (defaults to 2048) to keep the old behavior with path-realted functions (#700)

  • Use pathlib from the standard library, instead of pathtools (#556)

  • Allow file paths on Unix that don’t follow the file system encoding (#703)

  • Removed the long-time deprecated events.LoggingFileSystemEventHandler class, use LoggingEventHandler instead

  • Thanks to our beloved contributors: @SamSchott, @bstaletic, @BoboTiG, @CCP-Aporia

0.10.4

2020-11-21 • full history

  • Add logger parameter for the LoggingEventHandler (#676)

  • Replace mutable default arguments with if None implementation (#677)

  • Expand tests to Python 2.7 and 3.5-3.10 for GNU/Linux, macOS and Windows

  • [mac] Performance improvements for the fsevents module (#680)

  • [mac] Prevent compilation of watchdog_fsevents.c on non-macOS machines (#687)

  • [watchmedo] Handle shutdown events from SIGTERM and SIGINT more reliably (#693)

  • Thanks to our beloved contributors: @Sraw, @CCP-Aporia, @BoboTiG, @maybe-sybr

0.10.3

2020-06-25 • full history

  • Ensure ObservedWatch.path is a string (#651)

  • [inotify] Allow to monitor single file (#655)

  • [inotify] Prevent raising an exception when a file in a monitored folder has no permissions (#669, #670)

  • Thanks to our beloved contributors: @brant-ruan, @rec, @andfoy, @BoboTiG

0.10.2

2020-02-08 • full history

  • Fixed the build_ext command on macOS Catalina (#628)

  • Fixed the installation of macOS requirements on non-macOS OSes (#635)

  • Refactored dispatch() method of FileSystemEventHandler, PatternMatchingEventHandler and RegexMatchingEventHandler

  • [bsd] Improved tests support on non Windows/Linux platforms (#633, #639)

  • [bsd] Added FreeBSD CI support (#532)

  • [bsd] Restored full support (#638, #641)

  • Thanks to our beloved contributors: @BoboTiG, @evilham, @danilobellini

0.10.1

2020-01-30 • full history

  • Fixed Python 2.7 to 3.6 installation when the OS locale is set to POSIX (#615)

  • Fixed the build_ext command on macOS (#618, #620)

  • Moved requirements to setup.cfg (#617)

  • [mac] Removed old C code for Python 2.5 in the fsevents C implementation

  • [snapshot] Added EmptyDirectorySnapshot (#613)

  • Thanks to our beloved contributors: @Ajordat, @tehkirill, @BoboTiG

0.10.0

2020-01-26 • full history

Breaking Changes

  • Dropped support for Python 2.6, 3.2 and 3.3

  • Emitters that failed to start are now removed

  • [snapshot] Removed the deprecated walker_callback argument, use stat instead

  • [watchmedo] The utility is no more installed by default but via the extra watchdog[watchmedo]

Other Changes

  • Fixed several Python 3 warnings

  • Identify synthesized events with is_synthetic attribute (#369)

  • Use os.scandir() to improve memory usage (#503)

  • [bsd] Fixed flavors of FreeBSD detection (#529)

  • [bsd] Skip unprocessable socket files (#509)

  • [inotify] Fixed events containing non-ASCII characters (#516)

  • [inotify] Fixed the way OSError are re-raised (#377)

  • [inotify] Fixed wrong source path after renaming a top level folder (#515)

  • [inotify] Removed delay from non-move events (#477)

  • [mac] Fixed a bug when calling FSEventsEmitter.stop() twice (#466)

  • [mac] Support for unscheduling deleted watch (#541)

  • [mac] Fixed missing field initializers and unused parameters in watchdog_fsevents.c

  • [snapshot] Don’t walk directories without read permissions (#408)

  • [snapshot] Fixed a race condition crash when a directory is swapped for a file (#513)

  • [snasphot] Fixed an AttributeError about forgotten path_for_inode attr (#436)

  • [snasphot] Added the ignore_device=False parameter to the ctor (597)

  • [watchmedo] Fixed the path separator used (#478)

  • [watchmedo] Fixed the use of yaml.load() for yaml.safe_load() (#453)

  • [watchmedo] Handle all available signals (#549)

  • [watchmedo] Added the --debug-force-polling argument (#404)

  • [windows] Fixed issues when the observed directory is deleted (#570 and #601)

  • [windows] WindowsApiEmitter made easier to subclass (#344)

  • [windows] Use separate ctypes DLL instances

  • [windows] Generate sub created events only if recursive=True (#454)

  • Thanks to our beloved contributors: @BoboTiG, @LKleinNux, @rrzaripov, @wildmichael, @TauPan, @segevfiner, @petrblahos, @QuantumEnergyE, @jeffwidman, @kapsh, @nickoala, @petrblahos, @julianolf, @tonybaloney, @mbakiev, @pR0Ps, javaguirre, @skurfer, @exarkun, @joshuaskelly, @danilobellini, @Ajordat

0.9.0

2018-08-28 • full history

  • Deleting the observed directory now emits a DirDeletedEvent event

  • [bsd] Improved the platform detection (#378)

  • [inotify] Fixed a crash when the root directory being watched by was deleted (#374)

  • [inotify] Handle systems providing uClibc

  • [linux] Fixed a possible DirDeletedEvent duplication when deleting a directory

  • [mac] Fixed unicode path handling fsevents2.py (#298)

  • [watchmedo] Added the --debug-force-polling argument (#336)

  • [windows] Fixed the FILE_LIST_DIRECTORY constant (#376)

  • Thanks to our beloved contributors: @vulpeszerda, @hpk42, @tamland, @senden9, @gorakhargosh, @nolsto, @mafrosis, @DonyorM, @anthrotype, @danilobellini, @pierregr, @ShinNoNoir, @adrpar, @gforcada, @pR0Ps, @yegorich, @dhke

0.8.3

2015-02-11 • full history

  • Fixed the use of the root logger (#274)

  • [inotify] Refactored libc loading and improved error handling in inotify_c.py

  • [inotify] Fixed a possible unbound local error in inotify_c.py

  • Thanks to our beloved contributors: @mmorearty, @tamland, @tony, @gorakhargosh

0.8.2

2014-10-29 • full history

  • Event emitters are no longer started on schedule if Observer is not already running

  • [mac] Fixed usued arguments to pass clang compilation (#265)

  • [snapshot] Fixed a possible race condition crash on directory deletion (#281)

  • [windows] Fixed an error when watching the same folder again (#270)

  • Thanks to our beloved contributors: @tamland, @apetrone, @Falldog, @theospears

0.8.1

2014-07-28 • full history

  • Fixed anon_inode descriptors leakage (#249)

  • [inotify] Fixed thread stop dead lock (#250)

  • Thanks to our beloved contributors: @Witos, @adiroiban, @tamland

0.8.0

2014-07-02 • full history

  • Fixed argh deprecation warnings (#242)

  • [snapshot] Methods returning internal stats info were replaced by mtime(), inode() and path() methods

  • [snapshot] Deprecated the walker_callback argument

  • [watchmedo] Fixed auto-restart to terminate all children processes (#225)

  • [watchmedo] Added the --no-parallel argument (#227)

  • [windows] Fixed the value of INVALID_HANDLE_VALUE (#123)

  • [windows] Fixed octal usages to work with Python 3 as well (#223)

  • Thanks to our beloved contributors: @tamland, @Ormod, @berdario, @cro, @BernieSumption, @pypingou, @gotcha, @tommorris, @frewsxcv

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

watchdog-2.1.8.tar.gz (114.8 kB view details)

Uploaded Source

Built Distributions

watchdog-2.1.8-py3-none-win_ia64.whl (77.5 kB view details)

Uploaded Python 3 Windows ia64

watchdog-2.1.8-py3-none-win_amd64.whl (77.5 kB view details)

Uploaded Python 3 Windows x86-64

watchdog-2.1.8-py3-none-win32.whl (77.5 kB view details)

Uploaded Python 3 Windows x86

watchdog-2.1.8-py3-none-manylinux2014_x86_64.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-py3-none-manylinux2014_s390x.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-py3-none-manylinux2014_ppc64le.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-py3-none-manylinux2014_ppc64.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-py3-none-manylinux2014_i686.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-py3-none-manylinux2014_armv7l.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-py3-none-manylinux2014_aarch64.whl (77.5 kB view details)

Uploaded Python 3

watchdog-2.1.8-pp39-pypy39_pp73-macosx_10_9_x86_64.whl (95.0 kB view details)

Uploaded PyPy macOS 10.9+ x86-64

watchdog-2.1.8-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (95.0 kB view details)

Uploaded PyPy macOS 10.9+ x86-64

watchdog-2.1.8-pp37-pypy37_pp73-macosx_10_9_x86_64.whl (94.9 kB view details)

Uploaded PyPy macOS 10.9+ x86-64

watchdog-2.1.8-cp310-cp310-macosx_11_0_arm64.whl (87.2 kB view details)

Uploaded CPython 3.10 macOS 11.0+ ARM64

watchdog-2.1.8-cp310-cp310-macosx_10_9_x86_64.whl (86.6 kB view details)

Uploaded CPython 3.10 macOS 10.9+ x86-64

watchdog-2.1.8-cp310-cp310-macosx_10_9_universal2.whl (96.0 kB view details)

Uploaded CPython 3.10 macOS 10.9+ universal2 (ARM64, x86-64)

watchdog-2.1.8-cp39-cp39-macosx_11_0_arm64.whl (87.2 kB view details)

Uploaded CPython 3.9 macOS 11.0+ ARM64

watchdog-2.1.8-cp39-cp39-macosx_10_9_x86_64.whl (86.6 kB view details)

Uploaded CPython 3.9 macOS 10.9+ x86-64

watchdog-2.1.8-cp39-cp39-macosx_10_9_universal2.whl (96.0 kB view details)

Uploaded CPython 3.9 macOS 10.9+ universal2 (ARM64, x86-64)

watchdog-2.1.8-cp38-cp38-macosx_11_0_arm64.whl (87.2 kB view details)

Uploaded CPython 3.8 macOS 11.0+ ARM64

watchdog-2.1.8-cp38-cp38-macosx_10_9_x86_64.whl (86.6 kB view details)

Uploaded CPython 3.8 macOS 10.9+ x86-64

watchdog-2.1.8-cp38-cp38-macosx_10_9_universal2.whl (96.0 kB view details)

Uploaded CPython 3.8 macOS 10.9+ universal2 (ARM64, x86-64)

watchdog-2.1.8-cp37-cp37m-macosx_10_9_x86_64.whl (86.6 kB view details)

Uploaded CPython 3.7m macOS 10.9+ x86-64

watchdog-2.1.8-cp36-cp36m-macosx_10_9_x86_64.whl (86.6 kB view details)

Uploaded CPython 3.6m macOS 10.9+ x86-64

File details

Details for the file watchdog-2.1.8.tar.gz.

File metadata

  • Download URL: watchdog-2.1.8.tar.gz
  • Upload date:
  • Size: 114.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for watchdog-2.1.8.tar.gz
Algorithm Hash digest
SHA256 6d03149126864abd32715d4e9267d2754cede25a69052901399356ad3bc5ecff
MD5 44ed9dfb922e3716bcf8169a4cc3cf74
BLAKE2b-256 9061ddbf959d24fab35a98a8311e95d581e55109560e524f1a5a299ee991499d

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-win_ia64.whl.

File metadata

  • Download URL: watchdog-2.1.8-py3-none-win_ia64.whl
  • Upload date:
  • Size: 77.5 kB
  • Tags: Python 3, Windows ia64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for watchdog-2.1.8-py3-none-win_ia64.whl
Algorithm Hash digest
SHA256 0fb60c7d31474b21acba54079ce9ff0136411183e9a591369417cddb1d7d00d7
MD5 18c04deeb7674430a0540cc8c8be0383
BLAKE2b-256 c1dc8a970434bdfcc971032e816c5871a4758b3175589f51f0891826096b6825

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-win_amd64.whl.

File metadata

  • Download URL: watchdog-2.1.8-py3-none-win_amd64.whl
  • Upload date:
  • Size: 77.5 kB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for watchdog-2.1.8-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 88ef3e8640ef0a64b7ad7394b0f23384f58ac19dd759da7eaa9bc04b2898943f
MD5 0f05c6a79987e31ea7ab036e91847217
BLAKE2b-256 57ce351b40b7052ca746a33a1d0d562270877d79629d3211b2e6dae8b3da8d3e

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-win32.whl.

File metadata

  • Download URL: watchdog-2.1.8-py3-none-win32.whl
  • Upload date:
  • Size: 77.5 kB
  • Tags: Python 3, Windows x86
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.9.12

File hashes

Hashes for watchdog-2.1.8-py3-none-win32.whl
Algorithm Hash digest
SHA256 6ddf67bc9f413791072e3afb466e46cc72c6799ba73dea18439b412e8f2e3257
MD5 e11a03ae2c80f2b0e12772f4487d6736
BLAKE2b-256 75d78d1a2a81f83274715445f5dbd5bc41ddb9a9f92f5d26159889bd3ed07449

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 24dedcc3ce75e150f2a1d704661f6879764461a481ba15a57dc80543de46021c
MD5 c8d4aabad1352e3b5b48068a0d33ff7b
BLAKE2b-256 a3f3dd9eccfa6f0cee77932f621313c83b7e512ba9f7bac9628adc0bbc596e79

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_s390x.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_s390x.whl
Algorithm Hash digest
SHA256 fed4de6e45a4f16e4046ea00917b4fe1700b97244e5d114f594b4a1b9de6bed8
MD5 00466c4daabe225ce5a647296a6fc215
BLAKE2b-256 65c571bab2fa8c250e8bf8621dc490e63b95eb584c8d55da73fe718ddc8619c3

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_ppc64le.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_ppc64le.whl
Algorithm Hash digest
SHA256 47598fe6713fc1fee86b1ca85c9cbe77e9b72d002d6adeab9c3b608f8a5ead10
MD5 67e94bf7ab89fd26d7a6b38077051316
BLAKE2b-256 18bbf1fcae5a29502d0bb1c6737110bd81ed0fa3e9b7feeb68ede5277a8e1c55

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_ppc64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_ppc64.whl
Algorithm Hash digest
SHA256 156ec3a94695ea68cfb83454b98754af6e276031ba1ae7ae724dc6bf8973b92a
MD5 dd1f9f7266d4272d1c4bbb74a80dc3a2
BLAKE2b-256 6ad0ccde51fa157d5c3e60ecf9b03761d7107a3a12c4bd88d1c9eb822563029e

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_i686.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_i686.whl
Algorithm Hash digest
SHA256 2962628a8777650703e8f6f2593065884c602df7bae95759b2df267bd89b2ef5
MD5 4a97b23c9f1903fcc4710486f5964d0f
BLAKE2b-256 185713ce697eda3993a5bd4e1e790b91673acd01b1393b30267402ba853395b1

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_armv7l.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_armv7l.whl
Algorithm Hash digest
SHA256 036ed15f7cd656351bf4e17244447be0a09a61aaa92014332d50719fc5973bc0
MD5 ed2668cc6f738d8bdb2f3ff924d7eae5
BLAKE2b-256 c46c972379c77d9bd01e5d653b6807cd1142f1e41b964ee187dff18e788679fc

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-py3-none-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-py3-none-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 1e5d0fdfaa265c29dc12621913a76ae99656cf7587d03950dfeb3595e5a26102
MD5 36b63bf9a3b4e9f25dff78ba0cdaf777
BLAKE2b-256 7c52e660eb3e4d8503ce34548cbad06e143b3fc9c03819799a74b06e1ff7a881

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-pp39-pypy39_pp73-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-pp39-pypy39_pp73-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 b962de4d7d92ff78fb2dbc6a0cb292a679dea879a0eb5568911484d56545b153
MD5 f39fb9c17e214ffde1f789226c71478a
BLAKE2b-256 1decd2f427655256ca48697bf9570fae5dcfa98e01ad8b6961f443705e676403

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-pp38-pypy38_pp73-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-pp38-pypy38_pp73-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 4978db33fc0934c92013ee163a9db158ec216099b69fce5aec790aba704da412
MD5 06d8a4656ab443e362a3503b1d57dc59
BLAKE2b-256 51215dcedbc0feb427906b52f8d09ca839959c8badfff1f8d2fd4fda4a9e40d8

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-pp37-pypy37_pp73-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-pp37-pypy37_pp73-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 ddde157dc1447d8130cb5b8df102fad845916fe4335e3d3c3f44c16565becbb7
MD5 d0fa8a6b2f97779acca9cb9741d15575
BLAKE2b-256 5660fe4422071fe9c59866bc43a59aab5eb4d55a39ab5ce1cfd4f4419af06b1e

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 5e2e51c53666850c3ecffe9d265fc5d7351db644de17b15e9c685dd3cdcd6f97
MD5 b3bce4a544ac39cb819edb1317bff488
BLAKE2b-256 dd861ae6115ac9141d473b6ff781678502543f87bf6860b9e1490f11d1dd8658

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp310-cp310-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp310-cp310-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 aa68d2d9a89d686fae99d28a6edf3b18595e78f5adf4f5c18fbfda549ac0f20c
MD5 84b2b2aa0e4dbd87ad8eced85c7422e9
BLAKE2b-256 895f526a352f97094741cfa371390fe04e96e07b7f6e4657f350c2e0f39010b4

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp310-cp310-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp310-cp310-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 676263bee67b165f16b05abc52acc7a94feac5b5ab2449b491f1a97638a79277
MD5 6c725350fdc20ab4eb79db963b8f286b
BLAKE2b-256 9cb8fc5b75bddf4368197b482588dc9f21527c0fe982de223c0448401ad5fdc6

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp39-cp39-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp39-cp39-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 1ae17b6be788fb8e4d8753d8d599de948f0275a232416e16436363c682c6f850
MD5 b1ae303907579ea451e7f8ed67fb0b5b
BLAKE2b-256 f9a1167576852ffeb0c5692c9ebbf3b7d7310040ae3c4848fe46e4a8491ab6ad

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp39-cp39-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp39-cp39-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 746e4c197ec1083581bb1f64d07d1136accf03437badb5ff8fcb862565c193b2
MD5 4dc08f6fb1e5327da9a1d83540d6b9fa
BLAKE2b-256 f43b8e4d0d5a7f2598d325212a9efd9a392621e360838e94b67c03851b1fd49d

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp39-cp39-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp39-cp39-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 efcc8cbc1b43902571b3dce7ef53003f5b97fe4f275fe0489565fc6e2ebe3314
MD5 55557ba64b5ed8be2318e1aee6d02213
BLAKE2b-256 c9458e496143c58e421566b708ba3330398332c58df8cf6ffd74b4d2d357ffb3

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp38-cp38-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp38-cp38-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 0c520009b8cce79099237d810aaa19bc920941c268578436b62013b2f0102320
MD5 9dd1310e7133d46811cf18ac4d0a64bc
BLAKE2b-256 f61a93adb0e38f21494301645a38813835dba6f45828a009c4fd879e25ad86f4

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp38-cp38-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp38-cp38-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 68dbe75e0fa1ba4d73ab3f8e67b21770fbed0651d32ce515cd38919a26873266
MD5 59790015891ad84fa9a0d29e9774c9e4
BLAKE2b-256 759f71b53c9f16db00d73e50b89e79f5f716b671d4ffb1e72d1bf1a6de1452c0

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp38-cp38-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp38-cp38-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 f9ee4c6bf3a1b2ed6be90a2d78f3f4bbd8105b6390c04a86eb48ed67bbfa0b0b
MD5 59eff49285ec22309b216872adf0a492
BLAKE2b-256 0d58b8e6bffe106fe028d20c5cab4e43d3664fbf096b2acb46f54a5f71cd5229

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp37-cp37m-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp37-cp37m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 ce7376aed3da5fd777483fe5ebc8475a440c6d18f23998024f832134b2938e7b
MD5 f046c9dbff5214847e06b7c802261fa6
BLAKE2b-256 810af316ebf199613d19fd029dd0aa06800b069fd3503f1559b8e4702586601d

See more details on using hashes here.

File details

Details for the file watchdog-2.1.8-cp36-cp36m-macosx_10_9_x86_64.whl.

File metadata

File hashes

Hashes for watchdog-2.1.8-cp36-cp36m-macosx_10_9_x86_64.whl
Algorithm Hash digest
SHA256 7721ac736170b191c50806f43357407138c6748e4eb3e69b071397f7f7aaeedd
MD5 8556e19df3553ca4d71dc514ac0e687d
BLAKE2b-256 07a07021111da971189e48316a48406bcbb954593075f2afc33057b747454f95

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page