Это отличный вопрос, и я тоже искал что-то подобное, но я почти уверен, что в Наутилусе уже нет ничего подобного,
но если вы можете обратиться к некоторым сценариям, вы можете относительно легко адаптировать Nautilus file Notes
для выполнения чего-то подобного. Это потребует некоторого базового (+?) Скриптинга ..
С помощью file Notes
вы можете добавлять заметки в каталог, а также файлы ..
Был бы простой вопрос поиска в Notes для конкретной категории (ы) , а затем создать tempory ссылки (или постоянно) для каждого каталога с согласующими тегами в «Notes` ... затем положить эти ссылки в» поиск каталог результатов ... который вы бы затем представили в окне Nautilus! ...
Если бы у меня было свободное время, я бы сделал это сам, но вместо этого вот сценарий, который я написал для доступа, записи и удаления заметок Nautilus. Он не выполняет то, что я описал выше, но показывает, как получить доступ кэш данных Notes . Скрипт предназначен для использованияnautilus-actions
Сценарий находится на pastbin.ubuntu.com
ОБНОВЛЕНИЕ : я сейчас написал рабочий сценарий, который использует ссылки, как описано выше .. Однако я теперь поменял идею « nautilus Notes» и вместо этого привил в неизвестные файлы .tag пользователя. (Так что, если вам нравится сценарий Помните, что идея .tag - это «пользователь неизвестен» .
Мне нравятся простые текстовые файлы (они просты, универсальны и с ними очень легко работать).
Я использовал их locate
как инструмент поиска, так как он очень быстрый, но только в актуальном состоянии, как последний запуск updatedb
(который обычно ежедневно, но вы можете запустить его в любое время).
Я попытался объяснить использование скрипта в комментариях, но должен отметить, что он не полностью протестирован, поэтому он может неправильно работать с некоторыми незначительными моментами.
Единственное, что он удаляет / удаляет, это временный каталог и любые софт-ссылки. он содержит ... Обратите внимание, что удаление программных ссылок не приводит к удалению каталогов назначения / данных.
Вот сценарий
UPDATE2 : (исправлена ошибка. Он обрабатывал только первые 100 найденных файлов .tag)
#!/bin/bash
# Script: dirtags ...(by fred.bear)
#
# Summary: Open the file browser in a temporary directory
# which contains soft-links to directories whose
# '.tag' file contains the search string in $1
#
# .tag files are files you create in any directory which
# you wish to *tag*.
#
# .tag files are simple free form text, so you can
# put anything you like in them...
#
# The script uses `locate` to create a list of .tag file
# 'locate' is very fast, but because it depends on 'updatedb'
# for its list of current files, it can be a bit out of sync
# with a newly added .tag file... Modifying an existing
# .tag file does not effect `locate`
# To refresh the `locate` database, just run 'sudo updatedb'
# .. (updatedb typically auto-runs once a day, but you should check)
#
# Note: The search result soft links are put into a temporary directory
# This directory is removed each time you run the script
# TODO: allow saved searches (?) maybe
#
# Note: With nautilus, running the script a second time while
# the previoulsy opened wiondow is still open, cause the
# second window to open in its parent directory: /tmp/$USER
# ... but you can then just enter the 'dirtags' dir
# you see listed /tmp/$USER/$bname
# TODO: this probably happens because currently the
# directory is being removed each time the script
# is run... (related to "allow saved searches")
#
# A sample usage of this script:
#
# 1. Make a '.tag' file in each of several test directories.
# 2, For this first-time test, run 'sudo updatedb' so that the
# newly added .tag files are added to the 'locate's database
# 3. In each .tag file, put some tags (words or phrases to serch for)
# eg; action comedy drama good bad sci-fi documentary
# 4. Run this script with a single argument.. (a grep regex)
# eg "action|comedy"
#
function args_grep_links {
# $1 -- the grep regex
##echo grep -l '"'$1'"' ${tagged[@]}
< <(eval grep -l '$1' ${tagged[@]}) \
sed "s/^\(.*\)\/\.tag/ln -s \"\1\" $tagdbs/" \
>>"$tagdir"/.tag.slinks
##(gedit "$tagdir"/.tag.slinks &)
# make the soft links
source "$tagdir"/.tag.slinks
rm "$tagdir"/.tag.slinks
unset tagged
aix=
}
# Identity the script
bname="$(basename "$0")"
# Syntax
if [[ "$1" == "" ]] ; then
echo "ERROR: $bname requires one arg; a 'grep' regular expression string"
echo " eg: $bname \"music\" ......... Any instance of \"music\" .....(eg: \"musical\")"
echo " eg: $bname \"\<music\>\" ..... Only the word \"music\" ...(but not \"musical\")"
echo " eg: $bname \"muscic\|action\". Any instance of \"music\" or \"action\")"
exit 1
fi
# 'locate' the .tag files
# =======================
tagdir="/tmp/$USER/$bname"
tagdbs="${tagdir//\//\/}"
[[ -d "$tagdir" ]] && rm -rf "$tagdir" # remove all
[[ ! -d "$tagdir" ]] && mkdir -p "$tagdir" # fresh start
cp /dev/null "$tagdir"/.tag.slinks
unset tagged # array of .tag files
aix=0 # arg index
amax=10 # arg max per call to grep
fct=0 # file count
while IFS= read -r file ; do
tagged[$aix]="$file"
####echo ${tagged[aix]}
((aix++));((fct++))
(( aix == amax )) && args_grep_links "$1"
done < <(locate -ber ^\.tag$ |sed "s/.*/\"&\"/")
(( aix < amax )) && args_grep_links "$1"
sleep 1 # to allow time for rm to settle down after rm and adding links
xdg-open "$tagdir"
exit
#