HTML directory listing
Project description
LinuxDir2HTML
LinuxDir2HTML is a small program to help create an offline manifest of your files in an easily navigable html format. It is a CLI-only clone of Snap2HTML. LinuxDir2HTML is a rewrite of DiogenesList, making significant improvements to it:
- Python 3.6+
- Doesn't fail on symlinks (symlinks are optional)
- More graceful invocation and sane usage
- Much, much, much faster
- Highly improved code
LinuxDir2HTML will produce essentially an identical output to Snap2HTML by using the same HTML template from that project.
Installation
Python PIP Install
Linux
python -m pip install --user --upgrade linuxdir2html
macOS
python3 -m pip install --user --upgrade linuxdir2html
Add the --upgrade flag to install or upgrade.
Basic Install
There are no external dependencies. If you do not wish to use pip, download linuxdir2html.py
and template.html
. Run the python script directly.
Usage
The program takes two mandatory arguments, the directory to be indexed and the output file name without the extension. So:
linuxdir2html ~/Pictures output
will index the contents of /home/username/Pictures
and save the index as output.html
in the present working directory.
Extra options
There are five optional flags:
--hidden
to include hidden files and directories.
--links
to make the HTML link to the files directly.
--symlink
to follow symlinks. This flag is dangerous (circular references).
--silent
to suppress output. Good for scripting. Still prints errors.
--verbose
extra terminal output. Does not affect the results.
You should only enable the symlink flag if you have a known need for it.
By user request, newly introduced in v1.4.0 are a stacking --startswith
and --child
parameters. For example,
linuxdir2html --startswith 'dev' --child 'Pictures' ~ ~/output
will select directories that start with 'dev' and the directory named 'Pictures' from the the user's home directory. The --startswith
filter only affects the root search directory, all subdirectories and files will be indexed. The hidden flag is usable with the startswith flag.
License
The LinuxDir2HTML.py file is licensed under GPLv2.
The template.html file Copyright (C) by Dan and is licensed as GPLv3.
Known Issue
Files with * in their names will not break the html output, but it may cause issues with the --links feature, and truncate the file names and cause minor metadata issues. See this issue for more information.
Notes
- There are no plans to implement a GUI.
- The up-to-date template uses epoch time and converts to your locale. If you'd like to change this behavior, update the JS function
timestampToDate
in the template. - Certain characters like
\n
I've chosen to not implement handling for. In my humble opinion, just don't use new lines in file names :) - LinuxDir2HTML requires Python 3.6 or greater, but if you modify the code to remove string interpolation and the barely used pathlib, the minimum required version will be much lower.
Similar programs
I have long used an excellent program called ncdu to perform a similar function to WinDirStat or Disk Inventory X. I recently learned it has an export feature which you may find useful. Consider using it!
Export a directory and browse it once scanning is done:
ncdu -o- ~/book | tee ~/ncduscan.file | ncdu -f-
Browse the contents of the file, without rescanning:
ncdu -f ~/ncduscan.file
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
Built Distribution
File details
Details for the file linuxdir2html-1.6.0.tar.gz
.
File metadata
- Download URL: linuxdir2html-1.6.0.tar.gz
- Upload date:
- Size: 87.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3d182327b7d95bbe7d4be2665138973b0ab1777b3b5481009e7d99d15c63c79f |
|
MD5 | 67b7819b29ca080a2df6c6778db93bbb |
|
BLAKE2b-256 | d322869104bc9ca9a9e89532c26105c638a6d9a413ee9441857c9bfde2b8fb9f |
File details
Details for the file linuxdir2html-1.6.0-py3-none-any.whl
.
File metadata
- Download URL: linuxdir2html-1.6.0-py3-none-any.whl
- Upload date:
- Size: 86.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.1 CPython/3.10.8
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 357f009e2d4f7f6f8ca2af466e6ff53c8677bca6fbf8bc261728c809eb2fd9e2 |
|
MD5 | 788b646fe7962470f41dc8e80bea473f |
|
BLAKE2b-256 | 087f853c07d788a133080820f8bc9bbc90b27c1d793f53f24ddcaeb4e776f71c |