
Na etapa 1, estou tentando 'encontrar' o arquivo mais antigo na árvore de diretórios, que resolvi seguindoessa questão.
Agora quero usar xargs
para excluir interativamente do mais antigo para o mais novo.
Já que isso find -type f -printf '%T+ %p\n' | sort | xargs -0 -d '\n' rm -i
não funciona. Vi em outro post,
find . -type f -print0 | xargs -0 ls -rt
mas adicionar xargs
não funciona, infelizmente.
pi@raspberrypi:/usr/share/doc/samba$ find . -type f -print0 | xargs -0 ls -rt | xargs -0 -d '\n' rm -i
rm: remove write-protected regular file ‘./examples/LDAP/samba.schema.oc.IBM-DS’? rm: remove write-protected regular file ‘./examples/LDAP/samba-schema-netscapeds5.x.README’? rm: remove write-protected regular file ‘./examples/LDAP/samba-schema.IBMSecureWay’? rm: remove write-protected regular file ‘./examples/LDAP/samba.schema.gz’? rm: remove write-protected regular file ‘./examples/LDAP/samba-schema-FDS.ldif.gz’? rm: remove write-protected regular file ‘./examples/LDAP/samba.schema.at.IBM-DS.gz’? rm: remove write-protected regular file ‘./examples/LDAP/samba-nds.schema.gz’? rm: remove write-protected regular file ‘./examples/LDAP/samba.ldif.gz’? rm: remove write-protected regular file ‘./examples/LDAP/ol-schema-migrate.pl.gz’? rm: remove write-protected regular file ‘./examples/LDAP/get_next_oid’? rm: remove write-protected regular file ‘./README.Debian’? rm: remove write-protected regular file ‘./TODO.Debian’? rm: remove write-protected regular file ‘./NEWS.Debian.gz’? rm: remove write-protected regular file ‘./copyright’? rm: remove write-protected regular file ‘./changelog.Debian.gz’? rm: remove write-protected regular file ‘./examples/LDAP/README’?
Observe que este não é um problema de permissão. Usei /usr/share/doc/samba
como exemplo para evitar postar meus nomes de arquivos reais.
Pesquisando na web, não encontrei nenhum script que fosse recursivo (árvore inteira), manipulando caracteres de arquivo em branco e também interativo. Então eu fiz isso. Isso não lidaria com todos os tipos de caracteres especiais. Portanto, qualquer melhoria seria aceita.
#!/bin/bash
find -type f -printf '%T+ %p\n' | sort | head -n 3 > /tmp/1
cut -c32- /tmp/1 | awk '{print "rm -i", "\""$_"\""}'/tmp/2
bash /tmp/2
Responder1
Os únicos caracteres problemáticos que vejo no seu script são o "
e a nova linha. Você não deve se preocupar muito com a nova linha no nome de um arquivo.
Você pode querer usar nomes de arquivos temporários diferentes, por exemplo, com a $$
no nome do arquivo.
Então, como melhoria:
#!/bin/bash
TMP1=/tmp/file1.$$
TMP2=/tmp/file2.$$
find -type f -printf '%T+ %p\n' | sort | head -n 3 > $TMP1
cat $TMP1 | sed 's/"/\\"/g;s/[^ ]* //;s/^/rm -i "/;s/$/\"/' >$TMP2
bash $TMP2
rm -f $TMP1 $TMP2
Isso deve lidar com as aspas no nome do arquivo. (nota: ainda há alguns problemas com o script. No entanto, não há problema em fazer isso em seu próprio ambiente doméstico. E o TMP em maiúsculas não é recomendado, mas eu faço isso mesmo assim.)
Nota: xargs -p
não funcionará quando você tiver nomes de arquivos com espaços.
Responder2
Você estava quase lá.
Isso faz o que você deseja e lida com espaços em branco nos nomes de arquivos:
find -type f -printf '%T+ %p\n' | sort | cut -c32- | xargs -p -n1 -d '\n' rm
-p, --interactive
: pergunta ao usuário se deve executar cada linha de comando e ler uma linha do terminal. Execute a linha de comando apenas se a resposta começar com y ou Y.
-n max-args, --max-args=max-args
: use no máximo argumentos max-args por linha de comando.
-d delim
Os itens de entrada são finalizados pelo caractere especificado.