# Image Sorting Tool
[![Python Checks](https://github.com/ThorpeJosh/image-sorting-tool/actions/workflows/python-test.yml/badge.svg)](https://github.com/ThorpeJosh/image-sorting-tool/actions/workflows/python-test.yml)
[![PyPI version](https://img.shields.io/pypi/v/image-sorting-tool.svg)](https://pypi.org/project/image-sorting-tool/)
[![PyPI version](https://img.shields.io/pypi/pyversions/image-sorting-tool.svg)](https://pypi.org/project/image-sorting-tool/)
[![PyPI license](https://img.shields.io/pypi/l/image-sorting-tool.svg)](https://pypi.org/project/image-sorting-tool/)
![Screenshot](https://raw.githubusercontent.com/ThorpeJosh/image-sorting-tool/main/assets/ImageSortingTool.png)
This is a simple graphical tool to sort media into a structured folder. It is designed primarily for JPG images taken with a camera/phone but will also work with MP4, PNG and GIF media files. It works by finding all files in a chosen source directory (including sub-directories) and then based on the chosen sorting options, copies them into a structured destination.
The date-taken for JPG files is extracted from the EXIF data and for all other file formats the filename is used to extract the date-taken. The files destination name will be in format 'yyyymmdd_HHMMSS'. For example '20201225_234532.jpg'
The default output structure is year and month folders. For example:
/<br>
├── 2019/<br>
    ├── 07/<br>
        ├── 20190712_141507.jpg<br>
        └── 20190719_224521.jpg<br>
    └── 10/<br>
        ├── 20191011_180520.jpg<br>
        └── 20191029_204731.jpg<br>
└── 2020/<br>
    ├── 01/<br>
        └── 20200114_135312.jpg<br>
    └── 03/<br>
        └── 20200301_110330.jpg<br>
Files that cannot have the date-taken extracted (missing EXIF or bad filenames) will be copied to a 'failed_to_sort' folder in the root directory of the above structure without any renaming. These files are commonly ones downloaded from the internet or shared through social media.
If your source folder has other files such as binaries, documents, audio recordings, or music, you can choose if you want to ignore them or copy them to an 'other_files' folder with the 'Copy all other files' option.
This tool is multi-threaded to increase performance on high speed storage such as SSDs.
No data in the source directory is altered. It only reads from the source, and then copy operations are performed during the sorting process.
## Installation
The tool can be run on Linux, MacOS and Windows provided the following requirements are met
### Requirements
* [Python](https://www.python.org/downloads/) (compatible versions are listed at top of readme)
* python3-tk (Comes with Python 3, but may need installing separately in linux)
* [pipx](https://pipx.pypa.io/) (highly recommended, but `pip` will also work)
It is recommended to install `image-sorting-tool` with `pipx` as it will manage a dedicated environment and all paths for you, eliminating risk of dependency conflicts, etc.
To install run the following
```shell
pipx install image-sorting-tool
```
## Usage
Run the following to launch
```bash
image-sorting-tool
```
## Upgrading
Run the following to upgrade
```bash
pipx upgrade image-sorting-tool
```
## Uninstalling
Run the following to remove the tool from your machine
```bash
pipx uninstall image-sorting-tool
```
## Development
To contribute, clone this repo and then install the dev dependencies with
```shell
# Installs package locally so code changes will affect behaviour
pip install -e .[dev]
#Launch with -vv flag for debug logs
image-sorting-tool -vv
```
### Automated checks
Linting and unit tests should be checked before committing by running the following:
```bash
# Code formatting
black image-sorting-tool
# Linting
pylint image_sorting_tool
# Unit test on current environment python version
pytest
```
Raw data
{
"_id": null,
"home_page": "https://github.com/ThorpeJosh/image-sorting-tool",
"name": "image-sorting-tool",
"maintainer": null,
"docs_url": null,
"requires_python": "<3.14,>=3.9",
"maintainer_email": null,
"keywords": "image, sort, gui, executable",
"author": "Joshua Thorpe",
"author_email": "josh@thorpe.engineering",
"download_url": "https://files.pythonhosted.org/packages/11/27/b0fac0234bb49e491bc09878e3ebd3965c31822ea828df2c78ff46257b28/image_sorting_tool-1.2.0.tar.gz",
"platform": null,
"description": "# Image Sorting Tool\n[![Python Checks](https://github.com/ThorpeJosh/image-sorting-tool/actions/workflows/python-test.yml/badge.svg)](https://github.com/ThorpeJosh/image-sorting-tool/actions/workflows/python-test.yml)\n[![PyPI version](https://img.shields.io/pypi/v/image-sorting-tool.svg)](https://pypi.org/project/image-sorting-tool/)\n[![PyPI version](https://img.shields.io/pypi/pyversions/image-sorting-tool.svg)](https://pypi.org/project/image-sorting-tool/)\n[![PyPI license](https://img.shields.io/pypi/l/image-sorting-tool.svg)](https://pypi.org/project/image-sorting-tool/) \n![Screenshot](https://raw.githubusercontent.com/ThorpeJosh/image-sorting-tool/main/assets/ImageSortingTool.png)\nThis is a simple graphical tool to sort media into a structured folder. It is designed primarily for JPG images taken with a camera/phone but will also work with MP4, PNG and GIF media files. It works by finding all files in a chosen source directory (including sub-directories) and then based on the chosen sorting options, copies them into a structured destination.\n\nThe date-taken for JPG files is extracted from the EXIF data and for all other file formats the filename is used to extract the date-taken. The files destination name will be in format 'yyyymmdd_HHMMSS'. For example '20201225_234532.jpg'\nThe default output structure is year and month folders. For example:\n\n/<br>\n\u251c\u2500\u2500 2019/<br>\n    \u251c\u2500\u2500 07/<br>\n        \u251c\u2500\u2500 20190712_141507.jpg<br>\n        \u2514\u2500\u2500 20190719_224521.jpg<br>\n    \u2514\u2500\u2500 10/<br>\n        \u251c\u2500\u2500 20191011_180520.jpg<br>\n        \u2514\u2500\u2500 20191029_204731.jpg<br>\n\u2514\u2500\u2500 2020/<br>\n    \u251c\u2500\u2500 01/<br>\n        \u2514\u2500\u2500 20200114_135312.jpg<br>\n    \u2514\u2500\u2500 03/<br>\n        \u2514\u2500\u2500 20200301_110330.jpg<br>\n\nFiles that cannot have the date-taken extracted (missing EXIF or bad filenames) will be copied to a 'failed_to_sort' folder in the root directory of the above structure without any renaming. These files are commonly ones downloaded from the internet or shared through social media.\n\nIf your source folder has other files such as binaries, documents, audio recordings, or music, you can choose if you want to ignore them or copy them to an 'other_files' folder with the 'Copy all other files' option.\n\nThis tool is multi-threaded to increase performance on high speed storage such as SSDs.\n\nNo data in the source directory is altered. It only reads from the source, and then copy operations are performed during the sorting process.\n\n## Installation\nThe tool can be run on Linux, MacOS and Windows provided the following requirements are met\n### Requirements\n* [Python](https://www.python.org/downloads/) (compatible versions are listed at top of readme)\n* python3-tk (Comes with Python 3, but may need installing separately in linux)\n* [pipx](https://pipx.pypa.io/) (highly recommended, but `pip` will also work)\n\nIt is recommended to install `image-sorting-tool` with `pipx` as it will manage a dedicated environment and all paths for you, eliminating risk of dependency conflicts, etc.\n\nTo install run the following\n```shell\npipx install image-sorting-tool\n```\n\n## Usage\nRun the following to launch\n```bash\nimage-sorting-tool\n```\n## Upgrading\nRun the following to upgrade\n```bash\npipx upgrade image-sorting-tool\n```\n## Uninstalling\nRun the following to remove the tool from your machine\n```bash\npipx uninstall image-sorting-tool\n```\n\n## Development\nTo contribute, clone this repo and then install the dev dependencies with\n```shell\n# Installs package locally so code changes will affect behaviour\npip install -e .[dev]\n\n#Launch with -vv flag for debug logs\nimage-sorting-tool -vv \n```\n\n### Automated checks\nLinting and unit tests should be checked before committing by running the following:\n```bash\n# Code formatting\nblack image-sorting-tool\n\n# Linting\npylint image_sorting_tool\n\n# Unit test on current environment python version\npytest\n```\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "Graphical tool to sort images into a folder structure based on the date the images were taken",
"version": "1.2.0",
"project_urls": {
"Homepage": "https://github.com/ThorpeJosh/image-sorting-tool"
},
"split_keywords": [
"image",
" sort",
" gui",
" executable"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "861cfa5e9932acc96ceae38ffdaa3802a41c8f2fa3a1c0e98a99a8324e04da4c",
"md5": "6f5676ecead62fc9da8a24bb64385094",
"sha256": "7a3be21190d79c62bd35c604a039ba7b59a995f0bb37733a3098686a998ce9a9"
},
"downloads": -1,
"filename": "image_sorting_tool-1.2.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "6f5676ecead62fc9da8a24bb64385094",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<3.14,>=3.9",
"size": 14077,
"upload_time": "2024-10-28T10:59:33",
"upload_time_iso_8601": "2024-10-28T10:59:33.354081Z",
"url": "https://files.pythonhosted.org/packages/86/1c/fa5e9932acc96ceae38ffdaa3802a41c8f2fa3a1c0e98a99a8324e04da4c/image_sorting_tool-1.2.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "1127b0fac0234bb49e491bc09878e3ebd3965c31822ea828df2c78ff46257b28",
"md5": "b428bf329961ff71d3a0e1141e5ca780",
"sha256": "98635c8bfb3d73784c657971ad20e3c2c05de831092dc80516798f728751ba76"
},
"downloads": -1,
"filename": "image_sorting_tool-1.2.0.tar.gz",
"has_sig": false,
"md5_digest": "b428bf329961ff71d3a0e1141e5ca780",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<3.14,>=3.9",
"size": 14421,
"upload_time": "2024-10-28T10:59:34",
"upload_time_iso_8601": "2024-10-28T10:59:34.290043Z",
"url": "https://files.pythonhosted.org/packages/11/27/b0fac0234bb49e491bc09878e3ebd3965c31822ea828df2c78ff46257b28/image_sorting_tool-1.2.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-10-28 10:59:34",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "ThorpeJosh",
"github_project": "image-sorting-tool",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "image-sorting-tool"
}