|
NAMEaudio_rename - rename an audio file via information got via MP3::Tag.SYNOPSISaudio_rename -csR -@p "@a/@l/@02n_@t" . renames all the audio files in this directory and its subdirectories into a 3-level directory structure given by Artist_Name/Album/Filename, with the basename of Filename being the 2-digit track number separated from the title by underscore; it also transliterates cyrillic, and shortens long names. (Due to use of "-@" and double quotes, this command line should work both with UNIXish and DOSish shells; the other examples can be massaged likewise.) (Replacing @02n by "@{mA}@{n0}" (as in the default value of "-p") may provide more intelligent semantic. See the description of "-p". audio_rename -KD *.wav Reports how it would rename the *.wav files in this directory according to the default -p rule, but without protectiing "funny" characters. Will not do actual renaming. audio_rename -sc *.mp3 Rename the *.mp3 files in this directory according to the default -p rule, translating cyrillic characters into Latin "equivalents", shortening the names of long components, and protecting "funny" characters. audio_rename -p '%a/%{d0}/%B' -G '*/*.mp3' Assuming one-level subdirectory structure dir/filename.ext, finds files with extension .mp3, and "sorts" them into a two-level subdirectory structure; toplevel directory is based on the "artist" field, the remaing level is preserved. audio_rename -p '%a/%{d0}/%B' -R . Likewise, but does not suppose any particular depth of the current directory structure; only the filename and the most internal directory name are preserved. audio_rename -p '%a/%N' -R . Likewise, but all directory names (inside the current directory) are preserved. DESCRIPTIONThe script takes a list of files (or, with -R option, directories) and renames the given files (or audio files in the directories) according to the rules specified through the command line options. File extensions are preserved (by default).Some "companion" files (i.e., files with the same basename, and with an extension from a certain list) may be renamed together with audio files. A lot of care is taken to make the resulting file names as portable as possible: e.g., "funny" characters in file names are dumbed down (unless requested otherwise), long filename components may be shortened to certain limits. A care is taken so that renaming will not overwrite existing files; however, on OSes which allow rename() to overwrite files, race conditions can ruin the best intentions. E.g., do not run several "overlapping" rename procedures simultaneously! Recognized optionsGeneral use options:
The following options have the same meaning as for script "mp3info2"
File name portability options:
Note that this utility performes very similarly to mp3info2 utility when the latter one is used with -p option; only instead of printing the result of interpolation of -p, it uses the result as the target file name for renaming (after some "sanitizing" of the result). (However, the defaults for "-E" options differ!) Please take into account that the option -P is provided for completeness only. If one needs really complicated parsing rules to deduce the resulting file name, it is much safer to use mp3info2 utility to set the wanted file name into some ID3v2 frame (such as "TXXX[wanted-target-name]"), and then, after checking for errors, use this result similarly to audio_rename -p "%{TXXX[wanted-target-name]]}" -R . After rename, one can delete this frame from the resulting files. If you want to be absolutely error-prone, preserve the initial file name inside the files by doing something similar to mp3info2 -@F "TXXX[orig-fname]=@A" -R . before the rename. If worst comes to worst (but no race conditions happend, so files are not overwritten), one should be able to restore the status quo by running audio_rename -@p "@A" files_or_directories_list (giving -R option if needed). POSSIBLE PROBLEMSWith -R option, there might be situations when the scan of subdirectories first finds a source file in some directory, renames it, then continues the scan of other subdirectories, and will find the target file, so will try to rename it again.In practice, I do not recall ever encountering this situation; if the target file name depends only on the contents of the file, and not its name, then the second rename will be tautological, so not visible. AUTHORIlya Zakharevich <cpan@ilyaz.org>.SEE ALSOMP3::Tag, MP3::Tag::ParseData, mp3info2
Visit the GSP FreeBSD Man Page Interface. |