Найти файлы с помощью SQL-подобных запросов
Хотя он не имеет тенденции к полной замене традиционной find и ls , Fselect имеет эти хорошие функции:
.gitignore , .hgignore и .dockerignore (экспериментальная)Больше идет!
cargo install fselect Пакет AUR, спасибо @asm0dey
Aur Bin Package, спасибо @4censord
fselect в nixpkgs , спасибо @filalex77
Статическое строительство с мусульманином.
Статически предварительно скомпилированный двоичный файл доступен при загрузке GitHub.
winget install -e --id fselect.fselect choco install fselect scoop install fselect brew install fselect sudo port selfupdate
sudo port install fselect
fselect [ARGS] COLUMN[, COLUMN...] [from ROOT[, ROOT...]] [where EXPR] [group by COLUMNS] [order by COLUMNS] [limit N] [into FORMAT]
fselect -i
Более подробное описание. Сначала посмотрите на примеры.
Найдите временные или конфигурационные файлы (полный путь и размер):
fselect size, path from /home/user where name = '*.cfg' or name = '*.tmp'
Пользователи Windows могут опустить кавычки:
fselect size, path from C:Usersuser where name = *.cfg or name = *.tmp
Или поместите все аргументы в цитаты, подобные этим:
fselect "name from /home/user/tmp where size > 0"
Поиск в названии каталога с пробелами (также поддерживаются бэктики):
fselect "name from '/home/user/dir with spaces' where size > 0"
fselect "name from `/home/user/dir with spaces` where size > 0"
Или просто избежать единичных цитат:
fselect name from '/home/user/dir with spaces' where size gt 0
Укажите размер файла, получите абсолютный путь и добавьте его к результатам:
cd /home/user
fselect size, abspath from ./tmp where size gt 2g
fselect fsize, abspath from ./tmp where size = 5m
fselect hsize, abspath from ./tmp where size lt 8k
fselect name, size from ./tmp where size between 5mb and 6mb
Более сложный запрос:
fselect "name from /tmp where (name = *.tmp and size = 0) or (name = *.cfg and size > 1000000)"
Совокупные функции (вы можете использовать кудрявые скобки, если хотите, и даже объединить их с обычными скобками):
fselect "MIN(size), MAX{size}, AVG(size), SUM{size}, COUNT(*) from /home/user/Downloads"
Функции форматирования:
fselect "LOWER(name), UPPER(name), LENGTH(name), YEAR(modified) from /home/user/Downloads"
Получите год самого старого файла:
fselect "MIN(YEAR(modified)) from /home/user"
Используйте отдельные кавычки, если вам нужно обращаться к файлам с пробелами:
fselect "path from '/home/user/Misc stuff' where name != 'Some file'"
Поддерживаются регулярные выражения аромата ржавчины:
fselect name from /home/user where path =~ '.*Rust.*'
Отрицайте регулярные выражения:
fselect "name from . where path !=~ '^./config'"
Простые глобусы расширяются автоматически и работают с = и != Операторы:
fselect name from /home/user where path = '*Rust*'
Классический как:
fselect "path from /home/user where name like '%report-2018-__-__???'"
Операторы точных совпадений для поиска с отключенными Regexps:
fselect "path from /home/user where name === 'some_*_weird_*_name'"
Найти файлы по дате:
fselect path from /home/user where created = 2017-05-01
fselect path from /home/user where modified = today
fselect path from /home/user where accessed = yesterday
fselect "path from /home/user where modified = 'apr 1'"
fselect "path from /home/user where modified = 'last fri'"
Будьте более конкретны, чтобы соответствовать всем файлам, созданным с интервалом между 15:00 и 16:00:
fselect path from /home/user where created = '2017-05-01 15'
И еще более конкретно:
fselect path from /home/user where created = '2017-05-01 15:10'
fselect path from /home/user where created = '2017-05-01 15:10:30'
Возможны интервалы даты и времени (найдите все обновлено с 1 мая):
fselect path from /home/user where modified gte 2017-05-01
По умолчанию текущий каталог:
fselect path, size where name = '*.jpg'
Поиск в нескольких местах:
fselect path from /home/user/oldstuff, /home/user/newstuff where name = '*.jpg'
С указанной минимальной и/или максимальной глубиной ( depth является синонимом maxdepth ):
fselect path from /home/user/oldstuff depth 5 where name = '*.jpg'
fselect path from /home/user/oldstuff mindepth 2 maxdepth 5, /home/user/newstuff depth 10 where name = '*.jpg'
При желании следуйте Symlinks:
fselect path, size from /home/user symlinks where name = '*.jpg'
Поиск в архивах (в настоящее время поддерживается только Zip-Archives):
fselect path, size from /home/user archives where name = '*.jpg'
Или в комбинации:
fselect size, path from /home/user depth 5 archives symlinks where name = '*.jpg' limit 100
Включить .gitignore или .hgignore поддержка:
fselect size, path from /home/user/projects gitignore where name = '*.cpp'
fselect size, path from /home/user/projects git where name = '*.cpp'
fselect size, path from /home/user/projects hgignore where name = '*.py'
Поиск по размерам изображения:
fselect CONCAT(width, 'x', height), path from /home/user/photos where width gte 2000 or height gte 2000
Найдите квадратные изображения:
fselect path from /home/user/Photos where width = height
Найдите изображения с известной частью имени, но неизвестное расширение:
fselect path from /home/user/projects where name = "*RDS*" and width gte 1
Найдите файлы mp3 старой школы:
fselect duration, path from /home/user/music where genre = Rap and bitrate = 320 and mp3_year lt 2000
Ярлыки для общих расширений файлов:
fselect path from /home/user where is_archive = true
fselect path, mime from /home/user where is_audio = 1
fselect path, mime from /home/user where is_book != false
Даже более простой способ использования логических колонн:
fselect path from /home/user where is_doc
fselect path from /home/user where is_image
fselect path from /home/user where is_video
Найти файлы с опасными разрешениями:
fselect mode, path from /home/user where other_write or other_exec
fselect mode, path from /home/user where other_all
Возможны простые шарообразные выражения или даже регулярные выражения в режиме файла:
fselect mode, path from /home/user where mode = '*rwx'
fselect mode, path from /home/user where mode =~ '.*rwx$'
Найдите файлы по UID или GID владельца:
fselect uid, gid, path from /home/user where uid != 1000 or gid != 1000
Или по имени владельца или группы:
fselect user, group, path from /home/user where user = mike or group = mike
Найдите специальные файлы:
fselect name from /usr/bin where suid
fselect path from /tmp where is_pipe
fselect path from /tmp where is_socket
Найдите файлы с XATTR, проверьте, существует ли конкретный XATTR, или получите его значение:
fselect "path, has_xattrs, has_xattr(user.test), xattr(user.test) from /home/user"
Включите произвольный текст в виде столбцов:
fselect "name, ' has size of ', size, ' bytes'"
Результаты группы:
fselect "ext, count(*) from /tmp group by ext"
Результаты заказа:
fselect path from /tmp order by size desc, name
fselect modified, fsize, path from ~ order by 1 desc, 3
Наконец -то ограничьте результаты:
fselect name from /home/user/samples limit 5
Вывод формата:
fselect size, path from /home/user limit 5 into json
fselect size, path from /home/user limit 5 into csv
fselect size, path from /home/user limit 5 into html
MIT/Apache-2.0
Поддерживается лицензия Jetbrains Idea