Skip to main content

Better os.walk

Project description

stroll is a drop-in substitute for os.path.walk() with more features:

  • Unix-style globs or “star notation” like *.py

  • Walks over multiple roots

  • Calls expanduser to handle paths like ~/foo.txt

  • Yields pathlib.Path() instead of str

  • Yields full absolute paths by default

  • Can exclude or include files flexibly by pattern or function

  • Raises FileNotFoundError if a root directory doesn’t exist, instead of silently doing nothing like os.walk does

  • Excludes dotfiles by default

  • Includes two functions for ignoring generated files in a Python project:

    • The Python build, test and release cycle tend to leave generated files in places like build/ or __pycache__/, and usually you want to ignore these

    • stroll.python_source() iterates over Python source files

    • stroll.python() iterates over all source files in a Python project

    • The files and directories that are ignored are:
      • files or directories that start with a .

      • .egg-info/ and __pycache__/

      • build/, dist/ and htmlcov/ at the top level only

API

stroll()

stroll(
     roots='.',
     topdown=True,
     onerror=None,
     followlinks=False,
     include=None,
     exclude=<function dotfile at 0x10c6e47b8>,
     directories=False,
     relative=False,
     with_root=None,
     sort=True,
     suffix=None,
     separator=',',
     ignore_missing_roots=False,
)

(stroll.py, 59-228)

Directory walker that improves on os.walk().

For each directory in roots, walk through each file in each subdirectory and yield a Path to that file. Ignores dotfiles by default.

EXAMPLE

import stroll

for f in stroll('~/foo:~/bar'):
    if f.suffix == '.txt':
        print(f)

for f in stroll.python_source('/code/project'):
    assert f.suffix == '.py'
ARGUMENTS
roots

Either a list or tuple of strings, or a single string that is split using separator (defaults to ,, the comma).

topdown (argument to os.walk)

If optional arg topdown is true or not specified, the Path to a directory is generated before any of its subdirectories - directories are generated top-down.

If topdown is false, the Path to a directory is generated after all of its subdirectories - directories are generated bottom up.

onerror (argument to os.walk)

By default errors from the os.scandir() call are ignored. If optional arg onerror is specified, it should be a function; it will be called with one argument, an OSError instance. It can report the error to continue with the walk, or raise the exception to abort the walk. Note that the filename is available as the filename attribute of the exception object.

followlinks (argument to os.walk)

By default, os.walk() does not follow symbolic links to subdirectories on systems that support them. In order to get this functionality, set the optional argument followlinks to true.

Caution: if you pass a relative pathname for top, don’t change the current working directory between resumptions of walk. os.walk() never changes the current directory, and assumes that the client doesn’t either.

include

A list of patterns that files must match.

Patterns can either be a Unix-style match string, or a Python callable which returns True if the file matches

exclude

A list of patterns that files cannot match (and will skip).

Patterns can either be a Unix-style match string, or a Python callable which returns True if the file matches.

directories

If true, both files and directories are yielded. If false, the default, only files are yielded

relative

If true, file paths are relative to the root they were found in. If false, the default, absolute paths are generated.

with_root

If true, pairs looking like (root, filepath) are generated. If False, just file paths are generated. If None, the default, pairs are generated only if there is more than one root and relative paths are selected.

sort

If true, files or subdirectories are generated in sorted order. If false, the default, files or subdirectories are generated in whatever order the operating system gives them, which might be sorted anyway

suffix

If None, the default, there is no suffix matching. Note that include and exclude might match suffixes independently.

ignore_missing_roots

If true, root directories that do not exist are silently skipped. If false, the default, all roots are checked for existence before any files are generated.

stroll.python()

stroll.python(
     roots,
     topdown=True,
     onerror=None,
     followlinks=False,
     include=None,
     exclude=(<function dotfile at 0x10c6e47b8>, <function match_root at 0x10c754400>, <function match_suffix at 0x10c754488>, <function match at 0x10c754510>),
     directories=False,
     relative=False,
     with_root=None,
     sort=True,
     suffix=None,
     separator=',',
     ignore_missing_roots=False,
)

Iterate over a Python project, skipping generated files

stroll.python_source()

stroll.python_source(
     roots,
     topdown=True,
     onerror=None,
     followlinks=False,
     include='*.py',
     exclude=(<function dotfile at 0x10c6e47b8>, <function match_root at 0x10c754400>, <function match_suffix at 0x10c754488>, <function match at 0x10c754510>),
     directories=False,
     relative=False,
     with_root=None,
     sort=True,
     suffix=None,
     separator=',',
     ignore_missing_roots=False,
)

Iterate over *.py files in a Python project, skipping generated files

(automatically generated by doks on 2020-11-21T15:09:32.268025)

Project details


Download files

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

Source Distribution

stroll-1.1.0.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

stroll-1.1.0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file stroll-1.1.0.tar.gz.

File metadata

  • Download URL: stroll-1.1.0.tar.gz
  • Upload date:
  • Size: 8.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.6.6

File hashes

Hashes for stroll-1.1.0.tar.gz
Algorithm Hash digest
SHA256 778d23c31eaf49415b1c430b3b26b5498a60222e0f9f3338099af64a9e77f361
MD5 79bb4c1e5114b8398178d2182cedd02f
BLAKE2b-256 4dbd1b76ba6d1806022f430c1edba3bc74f6651c5fb7b79a0e01569d7e202f38

See more details on using hashes here.

File details

Details for the file stroll-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: stroll-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.2.0 requests-toolbelt/0.9.1 tqdm/4.48.0 CPython/3.6.6

File hashes

Hashes for stroll-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9b4c48cc84727f7bb9e0aae1eb3fcfc195ea4d9aaf81cb47dbf9cde6756f3476
MD5 c089d4f22c3dcb5252776f71cf17f727
BLAKE2b-256 8927bb7228da50750113278f4aa1be720584968f72026a2356d46be98e0d5459

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