26 releases (9 breaking)
new 0.17.11 | Nov 18, 2024 |
---|---|
0.17.8 | Sep 5, 2024 |
0.17.5 | Jul 25, 2024 |
#486 in Command line utilities
127 downloads per month
37KB
816 lines
phorg
Idempotent photo/video file organizer.
Overview
Given a <src>
and <dst>
directories:
- finds photo/video files in
<src>
- fetches their Exif data
- computes their hash digests
- moves/copies them into
<dst>/{<img>,<vid>}/<year>/<month>/<day>/<date>--<time>--<digest>[.<ext>]
where:<img>
and<vid>
default to "img" and "vid", respectively, and are customizable via CLI- date and time are extracted from Exif metadata, from whichever of the
following tags is found first, tried in order:
DateTimeOriginal
CreationDate
DateTimeCreated
CreateDate
DateCreated
Datecreate
TrackCreateDate
- optionally, you can (manually) add semantically-named subdirectories
underneath the
<day>
directory and (manually) move the media files into them, these subdirectories will then be preserved on subsequent reprocessings, i.e. when this<dst>
is later used as<src>
Example
(note the semantic subdirectory on 2020-11-29)
$ phorg /mnt/usb-drive $dst move
$ cd $dst
$ tree .
.
├── img
│ ├── 2020
│ │ ├── 11
│ │ │ ├── 29
│ │ │ │ └── Hike on Suffern-Bear Mountain Trail
│ │ │ │ ├── 2020-11-29--15:23:10--crc32:c7d15ddf.heic
│ │ │ │ ├── 2020-11-29--15:29:40--crc32:b4f4e4e0.heic
│ │ │ │ ├── 2020-11-29--15:30:07--crc32:3b5aa617.heic
│ │ │ │ └── 2020-11-29--15:38:30--crc32:514c9b0c.heic
│ │ │ └── 30
│ │ │ ├── 2020-11-30--08:20:00--crc32:08a5aa4a.heic
│ │ │ ├── 2020-11-30--08:23:41--crc32:bba07552.heic
│ │ │ ├── 2020-11-30--08:24:24--crc32:94c0f155.heic
Install
- Ensure a Rust
1.75.0
+ toolchain is installed: https://www.rust-lang.org/tools/install cargo install phorg
- Ensure
~/.cargo/bin/
is in yourPATH
phorg help
Dependencies
Hard
Only the Rust tools mentioned above, everything else will be handled by cargo
.
Soft
exiftool
, which is used as a fallback whenever we fail to extract the needed
metadata ourselves. This fallback can be disabled via CLI.
Absence of exiftool
in PATH
will cause errors which will be logged, but
will not disrupt execution and the files we could not read enough data
about will just be skipped.
Dependencies
~17–28MB
~421K SLoC