This is a very simple script. See the usage at the top of the script starting on line 28.
#!/bin/bash
# Author: Gabriel Burca (gburca dash mp3 at ebixio dot com)
# Version: 1.0
#
# Copyright (C) 2006-2009 Gabriel Burca (gburca dash mp3 at ebixio dot com)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
set -o nounset
set -o errexit
function usage () {
cat << EOF
Checks for particular id3v2 frames in a set of files.
Usage:
$0 <option> <FRAME> files...
Options:
-m | --missing Show files that are missing the frame
-h | --has Show files that have the frame
-s | --show Show the contents of the frame
-a | --all Show all the frames
For example, to find mp3's with no album art:
$0 -m APIC *.mp3
Some sample frames:
APIC - Cover art
TIT2 - Song name
TPE1 - Artist
TALB - Album
TCON - Genre
EOF
}
function FilesWithoutFrame() {
FRAME=$1
shift
for file in $@ ; do
id3v2 -R "$file" | egrep "^$FRAME " 2>&1 > /dev/null
if [ $? -gt 0 ]; then
# $file is missing $FRAME
echo $file
fi
done
}
function FilesWithFrame() {
FRAME=$1
shift
for file in $@ ; do
id3v2 -R "$file" | egrep "^$FRAME " 2>&1> /dev/null
if [ $? -eq 0 ]; then
# $file has $FRAME
echo $file
fi
done
}
function ShowFrameContents() {
FRAME=$1
shift
for file in $@ ; do
id3v2 -R "$file" | egrep "^$FRAME "
done
}
function ShowAll() {
for file in $@; do
echo
echo
id3v2 -R "$file"
done
}
################################################################################
# main()
################################################################################
if [ $# -lt 2 ]; then
usage
exit 1
fi
IFS_orig=$IFS
IFS='
'
case $1 in
-m | --missing)
shift
FilesWithoutFrame $@
;;
-h | --has)
shift
FilesWithFrame $@
;;
-s | --show)
shift
ShowFrameContents $@
;;
-a | --all)
shift
ShowAll $@
;;
*)
usage
exit 1
;;
esac
IFS=$IFS_orig
At one point I had a need to extract various pieces of information from the f-spot photo.db
file (that’s where f-spot keeps all the information), so I wrote this script. Posting it here in case others find it useful. I called it
f-spot-list
#!/bin/bash
# Author: Gabriel Burca (gburca dash fspotlist at ebixio dot com)
# Version: 1.0
#
# Copyright (C) 2006-2009 Gabriel Burca (gburca dash fspotlist at ebixio dot com)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
set -o nounset
set -o errexit
function usage () {
cat << EOF
Extracts various pieces of information from an f-spot photo.db file.
Usage:
$0 <photo.db> <option>
Options:
-P | --Photo Pictures in the Photo directory
-k | --links DIR... All pictures in DIR that are not links
-a | --all All pictures in database
-h | --has TAG... Show pictures tagged with the tag
-t | --tags Show all available tags
<photo.db> is usually "~/.config/f-spot/photos.db"
Ex:
- Find all photos tagged "Favorites" or "Web":
$0 photos.db -h Favorites Web | sort | uniq | sed 's|^file://||' \
| xargs -I linkName readlink -e linkName
EOF
}
function PhotosInPhotoDir() {
sqlite3 "$PHOTO_DB" "select id, uri from photos where uri like '%Photos%';"
}
function HasTag() {
for TAG in $@ ; do
SQL="select base_uri || filename from photos \
inner join photo_tags on photos.id = photo_tags.photo_id \
inner join tags on photo_tags.tag_id = tags.id \
where tags.name like '$TAG';"
#echo $SQL
sqlite3 "$PHOTO_DB" "$SQL"
done
}
function ShowNonLinks() {
for DIR in $@ ; do
find "$DIR" -type f
done
}
function ShowTags() {
sqlite3 "$PHOTO_DB" "select name from tags order by name;"
}
function ShowAll() {
sqlite3 "$PHOTO_DB" "select * from photos;"
}
################################################################################
# main()
################################################################################
if [ $# -lt 2 ]; then
usage
exit 1
fi
IFS_orig=$IFS
IFS='
'
PHOTO_DB=$1
shift
if [ ! -e "$PHOTO_DB" ]; then
usage
exit 2
fi
case $1 in
-P | --Photo)
shift
PhotosInPhotoDir $@
;;
-k | --links)
shift
ShowNonLinks $@
;;
-t | --tags)
shift
ShowTags $@
;;
-h | --has)
shift
HasTag $@
;;
-a | --all)
shift
ShowAll $@
;;
*)
usage
exit 1
;;
esac
IFS=$IFS_orig