Inspect the f-stop photo.db file
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
#!/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
			
		
Very nice, I can sur use it.. trying to convert all tags from f-spot to kphotoalbum. So f-spot-list -t works, but f-spot-list -h Tagname gives an error like SQL error: no such column: uri.
Too tired to investigate now.
Btw in my installation the database is ~/.config/f-spot/photos.db
so the issue was that in some versions of th f-spot database uri was replaced by base_uri,filename
@RZ
Script has now been updated to work with the newer versions of f-spot.