A User-Focused Photo & File Management System
TagStudio is a photo & file organization application with an underlying tag-based system that focuses on giving freedom and flexibility to the user. No proprietary programs or formats, no sea of sidecar files, and no complete upheaval of your filesystem structure. Read the documentation and more at docs.tagstud.io!
[!CAUTION]
As of Pull Request #332 (SQLite Migration) themain
branch will be an open test bed to get full JSON to SQL parity operational. This notice will be removed once parity between v9.4 and v9.5 is reached.For the most recent stable feature release branch, see the
Alpha-v9.4
branch. These v9.4 specific features are currently being backported to the SQL-izedmain
branch. Feel free to help!
[!NOTE]
This project is still in an early state. There are many missing optimizations and QoL features, as well as the presence of general quirks and occasional jankiness. Making frequent backups of your library save data is always important, regardless of what state the program is in.With this in mind, TagStudio will NOT:
- Touch, move, or mess with your files in any way (unless explicitly using the “Delete File(s)” feature, which is locked behind a confirmation dialog).
- Ask you to recreate your tags or libraries after new releases. It’s our highest priority to ensure that your data safely and smoothly transfers over to newer versions.
- Cause you to suddenly be able to recall your 10 trillion downloaded images that you probably haven’t even seen firsthand before. You’re in control here, and even tools out there that use machine learning still needed to be verified by human eyes before being deemed accurate.
TagStudio Alpha v9.4.2 running on Windows 10.
If you’re interested in contributing to TagStudio, please take a look at the contribution guidelines for how to get started!
Translation hosting generously provided by Weblate. Check out our project page to help translate TagStudio!
filename: <query>
).untagged
and empty
.* Weird files with no extension or files such as “._DS_Store” currently have limited support.
** Audio playback coming in v9.5
[!NOTE]
For more information on the project itself, please see the FAQ section as well as the documentation.
To download TagStudio, visit the Releases section of the GitHub repository and download the latest release for your system under the “Assets” section. TagStudio is available for Windows, macOS (Apple Silicon & Intel), and Linux. Windows and Linux builds are also available in portable versions if you want a more self-contained executable to move around.
We do not currently publish TagStudio to any package managers. Any TagStudio distributions outside of the GitHub releases page are unofficial and not maintained by us. Installation support will not be given to users installing from unofficial sources. Use these versions at your own risk.
[!IMPORTANT]
On macOS, you may be met with a message saying ““TagStudio” can’t be opened because Apple cannot check it for malicious software.” If you encounter this, then you’ll need to go to the “Settings” app, navigate to “Privacy & Security”, and scroll down to a section that says ““TagStudio” was blocked from use because it is not from an identified developer.” Click the “Open Anyway” button to allow TagStudio to run. You should only have to do this once after downloading the application.
Arguments available to pass to the program, either via the command line or a shortcut.
--open <path>
/-o <path>
Path to a TagStudio Library folder to open on start.
--config-file <path>
/-c <path>
Path to the TagStudio config file to load.
With TagStudio opened, start by creating a new library or opening an existing one using File -> Open/Create Library from the menu bar. TagStudio will automatically create a new library from the chosen directory if one does not already exist. Upon creating a new library, TagStudio will automatically scan your folders for files and add those to your library (no files are moved during this process!).
In order to scan for new files or file changes, you’ll need to manually go to File -> Refresh Directories.
[!NOTE]
In the future, library refreshing will also be automatically done in the background, or additionally on app startup.
To add a metadata field to a file entry, start by clicking the “Add Field” button under the file preview in the right-hand preview panel. From the dropdown menu, select the type of metadata field you’d like to add to the entry.
Hover over the field and click the pencil icon. From there, add or edit text in the dialog box popup.
Click the “+” button at the end of the Tags list, and search for tags to add inside the new dialog popup. Click the “+” button next to whichever tags you want to add. Alternatively, after you search for a tag, press the Enter/Return key to add the add the first item in the list. Press Enter/Return once more to close the dialog box
[!WARNING]
Keyboard control and navigation is currently very buggy, but will be improved in future versions.
To create a new tag, click on Edit -> New Tag from the menu bar. From there, enter a tag name, shorthand name, any tag aliases separated by newlines, any subtags, and an optional color.
To edit a tag, right-click the tag in the tag field of the preview pane and select “Edit Tag”
Inevitably, some of the files inside your library will be renamed, moved, or deleted. If a file has been renamed or moved, TagStudio will display the thumbnail as a red tag with a cross through it (this icon is also used for items with broken thumbnails). To relink moved files or delete these entries, go to Tools -> Manage Unlinked Entries. Click the “Refresh” button to scan your library for unlinked entries. Once complete, you can attempt to “Search & Relink” any unlinked entries to their respective files, or “Delete Unlinked Entries” in the event the original files have been deleted and you no longer wish to keep their metadata entries inside your library.
[!WARNING]
There is currently no method to relink entries to files that have been renamed - only moved or deleted. This is a top priority for future releases.
[!WARNING]
If multiple matches for a moved file are found (matches are currently defined as files with a matching filename as the original), TagStudio will currently ignore the match groups. Adding a GUI for manual selection, as well as smarter automated relinking, are top priorities for future versions.
Libraries are saved upon exiting the program. To manually save, select File -> Save Library from the menu bar. To save a backup of your library, select File -> Save Library Backup from the menu bar. Automatic backups are created when loading a library, and are automatically loaded from in the event of a crash or unexpected system shutdown.
Load in a .dupeguru file generated by dupeGuru and mirror metadata across entries marked as duplicates. After mirroring, return to dupeGuru to manage deletion of the duplicate files. After deletion, use the “Fix Unlinked Entries” feature in TagStudio to delete the duplicate set of entries for the now-deleted files
[!CAUTION]
While this feature is functional, it’s a pretty roundabout process and can be streamlined in the future.
Create an image collage of your photos and videos.
[!CAUTION]
Collage sizes and options are hardcoded, and there’s no GUI indicating the process of the collage creation.
Apply tags and other metadata automatically depending on certain criteria. Set specific macros to run when the files are added to the library. Part of this includes applying tags automatically based on parent folders.
[!CAUTION]
Macro options are hardcoded, and there’s currently no way for the user to interface with this (still incomplete) system at all.
Import JSON sidecar data generated by gallery-dl.
[!CAUTION]
This feature is not supported or documented in any official capacity whatsoever. It will likely be rolled-in to a larger and more generalized sidecar importing feature in the future.
See instructions in the “Creating Development Environment” section from the contribution documentation.
As of writing (Alpha v9.4.2) the project is in a useable state, however includes several metadata field bugs and lacks several quality of life features. Focus has been on developing v9.5 with a new SQLite backend which will allow us to not only fix these bugs but also to give us a jumping off point for some pretty cool features we’ve been wanting to add for quite a while now!
See the Feature Roadmap page for the core features being planned and implemented for TagStudio. For a more up to date look on what’s currently being added for upcoming releases, see our GitHub milestones for versioned releases.
Over the first few years of private development the project went through several major iterations and rewrites. These major version bumps came quickly, and by the time TagStudio was opened-sourced the version number had already reached v9.0. Instead of resetting to “v0.0” or “v1.0” for this public release I decided to keep my v9.x numbering scheme and reserve v10.0 for when all the core features on the Feature Roadmap are implemented. I’ve also labeled this version as an “Alpha” and will drop this once either all of the core features are implemented or the project feels stable and feature-rich enough to be considered “Beta” and beyond.