List directory contents as Polars DataFrames
Project description
pols
List directory contents as Polars DataFrames.
Installation
- Requires installation of either
polarsorpolars-lts-cpu.
pip install polars-ls
User guidance
Names are relative
Counter to the typical pathlib.Path notion of a name, the names in ls and hence pols are
more relative names: hence . is a valid name (if you try accessing the .name attribute of a
pathlib Path, it'll come back as "").
>>> cwd = Path.cwd()
>>> cwd / "."
PosixPath('/home/louis/dev/pols')
>>> cwd / ".."
PosixPath('/home/louis/dev/pols/..')
>>> (cwd / ".").name
'pols'
>>> (cwd / "..").name
'..'
>>> Path(".").name
''
Individual files and directories don't mix
The way ls works is that individual files get collected in one 'set' of results and directories
in another, and never the two shall meet. If you ls a few files and one or more directories,
you'll get one set of reults with all the files and one set for each of the folders. This is
because of the previous point: the names shown are relative to the directory 'root' (if you're
specifying files individually, the current working directory is the assumed directory 'root', and
of course absolute paths always show as absolute so their 'root' is shown too).
(Even if the individual files are in different folders: it's because merging files with different roots whose relative names are being shown would be invalid)
$ ls README.md src src/pols/__init__.py
README.md src/pols/__init__.py
src:
pols
To the same effect, the results are grouped in a list of dicts, where the key is the source
(either the empty string for the individual files, or the directory root). This allows an identical
printout style to ls:
$ ls -A ../.py*
../.python-version
../.pytest_cache:
CACHEDIR.TAG .gitignore README.md v
$ pols -A ../.py*
shape: (1, 1)
┌────────────────────┐
│ name │
│ --- │
│ str │
╞════════════════════╡
│ ../.python-version │
└────────────────────┘
../.pytest_cache:
shape: (4, 1)
┌──────────────┐
│ name │
│ --- │
│ str │
╞══════════════╡
│ README.md │
│ v │
│ .gitignore │
│ CACHEDIR.TAG │
└──────────────┘
Globs (Kleene stars) go 1 level deep
You can use ** in ls and pols but in both cases you only actually get one level, unlike other
tools (and Python's glob).
$ ls src/pols/**.py
src/pols/cli.py src/pols/__init__.py src/pols/pols.py
$ ls src/pols/*/*.py
src/pols/features/a.py src/pols/features/A.py src/pols/features/hide.py
src/pols/features/__init__.py src/pols/features/p.py
Differences from ls
The design is intended to keep as closely as possible to GNU coreutils
ls.
So far one particular divergence is that command line order does not affect pols
(e.g. -aA vs -Aa), but there is no real way to implement this with boolean parameters.
It could be detected for a CLI but for now I'm prioritising feature completeness over CLI
complexity (it is autogenerated from the function signature with
argh).
Another is that hide is not disabled by a/A because there is no need to, and this enables
filtering hidden files minus some pattern. In ls, --hide silently fails if passed with -a.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file polars_ls-0.1.3.tar.gz.
File metadata
- Download URL: polars_ls-0.1.3.tar.gz
- Upload date:
- Size: 10.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.22.3 CPython/3.12.8 Linux/6.8.0-51-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d3e181e476334567b06c94a5b4196b1cbcfac51c52e9ffa775239423a9f4c9f9
|
|
| MD5 |
4864447c91e8f24d7fd9f0cfccdf7f8b
|
|
| BLAKE2b-256 |
a406cb88afa514d9418ee5387a456dc003d89134f1f1ef1ce0a0b2ef1267212e
|
File details
Details for the file polars_ls-0.1.3-py3-none-any.whl.
File metadata
- Download URL: polars_ls-0.1.3-py3-none-any.whl
- Upload date:
- Size: 9.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: pdm/2.22.3 CPython/3.12.8 Linux/6.8.0-51-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
97bafff4f0afa926d80b36b405e85a393569763e6fbac54213dd3cc19a65c224
|
|
| MD5 |
e9bb0239f973b095ce2f653855250573
|
|
| BLAKE2b-256 |
1e59d15e22e587b414b17229a6cd0b355ee1d725ca096d39a49898d4b498a3de
|