कचरा करने के लिए `rm` करें


54

क्या कोई लिनक्स स्क्रिप्ट / एप्लिकेशन है, जो फ़ाइलों को हटाने के बजाय, उन्हें एक विशेष "कचरा" स्थान पर ले जाता है? मैं इसे एक प्रतिस्थापन के रूप में पसंद कर सकता हूं rm(शायद बाद वाले को भी अलियास कर रहा है; इसके लिए पेशेवरों और विपक्ष हैं)।

"कचरा" से मेरा मतलब एक विशेष फ़ोल्डर से है। एक एकल mv $* ~/.trashएक पहला कदम है, लेकिन आदर्श रूप में इसे पुरानी ट्रैश किए गए फ़ाइलों को अधिलेखित किए बिना एक ही नाम की कई फ़ाइलों को ट्रैश करना चाहिए, और एक साधारण कमांड ("पूर्ववत करें") के साथ अपने मूल स्थान पर फ़ाइलों को पुनर्स्थापित करने की अनुमति दें । इसके अलावा, यह अच्छा होगा यदि कचरा रिबूट (या अंतहीन विकास को रोकने के लिए एक समान तंत्र) पर स्वचालित रूप से खाली हो गया था।

इसके लिए आंशिक समाधान मौजूद हैं, लेकिन विशेष रूप से "पुनर्स्थापना" कार्रवाई तुच्छ नहीं है। क्या इसके लिए कोई मौजूदा समाधान हैं जो एक ग्राफिकल शेल से कचरा प्रणाली पर निर्भर नहीं हैं?

(एक तरफ के रूप में, अंतहीन चर्चा हुई है कि क्या यह दृष्टिकोण उचित है, बजाय लगातार बैकअप और वीसीएस का उपयोग करने के। जबकि उन चर्चाओं का एक बिंदु है, मेरा मानना ​​है कि मेरे अनुरोध के लिए अभी भी एक जगह है।)


4
यह सुपरयूजर प्रश्न से संबंधित हो सकता है दो फ़ाइलों को कचरा करने के लिए स्थानांतरित करने के लिए आदेश। क्या फर्क पड़ता है? । मैंने gvfs-trashअतीत में उपयोग किया है, लेकिन जब तक आपने मेरी जिज्ञासा को नहीं जगाया, कमांड-लाइन से पुनर्स्थापित करने की आवश्यकता नहीं थी। लिंक किए गए प्रश्न का उत्तर मदद का हो सकता है।
इफिथिथ

1
@ephsmith धन्यवाद, अच्छी कड़ी। हालांकि उन दृष्टिकोणों के साथ समस्या यह है कि वे विशिष्ट डेस्कटॉप शेल (यहां सही शब्द क्या है?) कार्यान्वयन के लिए बाध्य हैं, कुछ ऐसा जिससे मैं बचना चाहता हूं।
कोनराड रुडोल्फ

1
क्या किसी भी फाइल सिस्टम से फाइल आपके ~ इरादतन में जा रही है? क्योंकि किसी दिन आपको वास्तव में रिमोट सर्वर से sshfs के साथ मुहिम शुरू की गई एक 4GB आईएसओ छवि को हटाना हो सकता है।
मिशा आरिफिएव जूल

1
@ मिचा ईमानदार होने के लिए, मैंने इसमें उतना विचार नहीं किया। उस ने कहा, इसे सामान्य उपयोगकर्ता के अधिकारों के साथ काम करना चाहिए, इसलिए लक्ष्य को एक ऐसा स्थान होना चाहिए जो लेखन योग्य हो और इसके लिए बहुत अधिक कॉन्फ़िगरेशन की आवश्यकता न हो।
कोनराड रुडोल्फ

3
आप जो भी चाहते हैं जैसे कि नीचे दिए गए उत्तरों में उल्लिखित समाधान है, लेकिन इसे आरएम नाम दें। जैसा कि दूसरों द्वारा बताया गया है, मानक आदेशों का नाम बदलने / पुन: उपयोग करने से आप कमजोर पड़ जाते हैं जब आप आदतन उन्हें अन्य प्रणालियों पर उपयोग करने का प्रयास करते हैं, लेकिन यह अप्रत्याशित परिणाम आने पर आपके सिस्टम / खाते का उपयोग करके किसी और (शायद आपकी सहायता करने) के लिए समस्या पैदा करेगा।
जो

जवाबों:


37

Freedesktop.org पर ट्रैश के लिए एक विनिर्देश (ड्राफ्ट) है । यह स्पष्ट रूप से डेस्कटॉप वातावरणों द्वारा आमतौर पर लागू किया जाता है।

एक कमांडलाइन कार्यान्वयन कचरा पेटी होगा । करीब से देखने के बिना, यह आपके द्वारा दी जाने वाली मज़ेदारता प्रदान करता है। यदि नहीं, तो हमें बताएं कि यह केवल एक आंशिक समाधान है।

जहां तक ​​किसी भी कार्यक्रम को प्रतिस्थापन / उर्फ ​​के रूप में उपयोग करने rmका सवाल है, ऐसा न करने के अच्छे कारण हैं। मेरे लिए सबसे महत्वपूर्ण हैं:

  • कार्यक्रम को सभी rmविकल्पों को समझने / संभालने और तदनुसार कार्य करने की आवश्यकता होगी
  • यह आपके "नए आरएम" के शब्दार्थों के लिए उपयोग किए जाने और अन्य प्रणालियों पर काम करने पर घातक परिणामों के साथ आदेश देने का जोखिम है

लिबरट्रश भी है जो सभी हटाए गए फ़ाइलों को LD_PRELOAD के माध्यम से स्वचालित रूप से कूड़े में ले जाता है (लेकिन ऐसा लगता है कि इसमें कई बग हैं)। ऑटोट्रैश कचरे को आसान तरीके से साफ करने में मदद करता है।
जोफेल

मैं इस आदत के बारे में सोच रहा हूँ, rm का उपयोग करने की आदत। मैं पहले से ही अभागा हूँ।
कोनराड रूडोल्फ

@ जोफेल: लिबरट्रश की वास्तव में अच्छी अवधारणा है। अन्य परतों की तुलना में कुछ परतें गहरी होती हैं। यह एक दया है कि यह छोटी गाड़ी है (और बहुत सक्रिय नहीं लगती है)।
zpea

4
@KonradRudolph: मेरा मतलब था कि एक व्यक्ति को इस तथ्य की आदत हो जाती है कि आरएम (प्रतिस्थापित एक) वास्तव में कुछ भी नहीं हटाता है, ताकि कोई कम सावधानी बरतें, क्योंकि एक पुनर्स्थापना हमेशा संभव है। बेशक, आरएम का उपयोग करना कोई बुरी बात नहीं है, न ही इसकी आदत है।
zpea

4
मैंने इस समाधान का उपयोग करना समाप्त कर दिया है, और अक्षम rmकर रहा हूं इसलिए मैं इसे गलती से उपयोग नहीं कर सकता हूं ( /bin/rmयदि मुझे वास्तव में इसकी आवश्यकता है तो अभी भी है)।
कोनराड रुडोल्फ

9

ट्रैश-क्लि एक लिनक्स एप्लिकेशन है जिसे उबंटू में एप्ट-गेट का उपयोग करके स्थापित किया जा सकता है या फेडोरा में यम। कमांड का उपयोग करने trash listOfFilesसे निर्दिष्ट आपके कचरा बिन में चला जाएगा।


इस सुझाव के समर्थन में: apple.stackexchange.com/a/17637/37190
Ioannis Filippidis

7

पिछले उत्तरों में कमांड्स trash-cliऔर उल्लेख हैं rmtrash। उबंटू 18.04 पर न तो डिफ़ॉल्ट रूप से पाए जाते हैं, लेकिन कमांड gioहै। कमांडिंग gio help trashआउटपुट:

Usage:
  gio trash [OPTION…] [LOCATION...]

Move files or directories to the trash.

Options:
  -f, --force     Ignore nonexistent files, never prompt
  --empty         Empty the trash

मैंने gio trash FILENAMEकमांड लाइन का उपयोग करके परीक्षण किया , और यह ठीक उसी तरह काम करता है जैसे मैंने फ़ाइल ब्राउज़र में फ़ाइल का चयन किया और DEL बटन पर क्लिक किया: फ़ाइल को डेस्कटॉप के ट्रैश फ़ोल्डर में ले जाया गया। ( -fविकल्प का उपयोग नहीं करने पर भी कमांड पुष्टि के लिए संकेत नहीं देता है।)

फ़ाइलों को इस तरह से हटाना प्रतिवर्ती है, जबकि सुरक्षा के लिए पुनर्परिभाषित rmकरने से अधिक सुविधाजनक होना rm -iऔर प्रत्येक विलोपन की पुष्टि करना, जो अभी भी आपको भाग्य से छोड़ देता है यदि आप गलती से एक विलोपन की पुष्टि करते हैं जो आपके पास नहीं होना चाहिए।

मैंने alias tt='gio trash'अपनी उपनाम परिभाषा फ़ाइल में जोड़ा ; ttटू ट्रैश के लिए एक महामारी है।

2018-06-27 को संपादित पर जोड़ा गया: सर्वर मशीनों पर, कचरा निर्देशिका के बराबर नहीं है। मैंने निम्नलिखित बैश स्क्रिप्ट लिखी है जो काम करती है; डेस्कटॉप मशीनों पर, यह उपयोग करता है gio trash, और अन्य मशीनों पर, फ़ाइल (नों) को पैरामीटर (रों) के रूप में एक ट्रैश निर्देशिका में ले जाता है जो इसे बनाता है। 2019-09-05 को स्क्रिप्ट अपडेट की गई।

#!/bin/bash
#
# move-to-trash
#
# Teemu Leisti 2019-09-05
#
# This script moves the files given as arguments to the trash directory, if they
# are not already there. It works both on (Gnome) desktop and server hosts.
#
# The script is intended as a command-line equivalent of deleting a file from a
# graphical file manager, which, in the usual case, moves the deleted file(s) to
# a built-in trash directory. On server hosts, the analogy is not perfect, as
# the script does not offer the functionality of restoring a trashed file to its
# original location, nor that of emptying the trash directory; rather, it offers
# an alternative to the 'rm' command, giving the user the peace of mind that
# they can still undo an unintended deletion before emptying the trash
# directory.
#
# To determine whether it's running on a desktop host, the script tests for the
# existence of the gio utility and of directory ~/.local/share/Trash. In case
# both exist, the script relies on the 'gio trash' command. Otherwise, it treats
# the host as a server.
#
# There is no built-in trash directory on server hosts, so the first invocation
# of the script creates directory ~/.Trash/, unless it already exists.
#
# The script appends a millisecond-resolution time stamp to all the files it
# moves to the trash directory, both to inform the user of the time of the
# deletion, and to avoid overwrites when moving a file to trash.
#
# The script will not choke on a nonexistent file. It outputs the final
# disposition of each argument: does not exist, was already in trash, or was
# moved to trash.


gio_command_exists=0
command -v gio > /dev/null 2>&1
if (( $? == 0 )) ; then
    gio_command_exists=1
fi

# Exit on using an uninitialized variable, and on a command returning an error.
# (The latter setting necessitates appending " || true" to those arithmetic
# calculations and other commands that can return 0, lest the shell interpret
# the result as signalling an error.)
set -eu

is_desktop=0

if [[ -d ~/.local/share/Trash ]] && (( gio_command_exists == 1 )) ; then
    is_desktop=1
    trash_dir_abspath=$(realpath ~/.local/share/Trash)
else
    trash_dir_abspath=$(realpath ~/.Trash)
    if [[ -e $trash_dir_abspath ]] ; then
        if [[ ! -d $trash_dir_abspath ]] ; then
            echo "The file $trash_dir_abspath exists, but is not a directory. Exiting."
            exit 1
        fi
    else
        mkdir $trash_dir_abspath
        echo "Created directory $trash_dir_abspath"
    fi
fi

for file in "$@" ; do
    file_abspath=$(realpath -- "$file")
    file_basename=$(basename -- "$file_abspath")
    if [[ ! -e $file_abspath ]] ; then
        echo "does not exist:   $file_abspath"
    elif [[ "$file_abspath" == "$trash_dir_abspath"* ]] ; then
        echo "already in trash: $file_abspath"
    else
        if (( is_desktop == 1 )) ; then
            gio trash "$file_abspath" || true
        else
            # The name of the moved file shall be the original name plus a
            # millisecond-resolution timestamp.
            move_to_abspath="$trash_dir_abspath/$file_basename-$(date '+%Y-%m-%d-at-%H-%M-%S.%3N')"
            while [[ -e "$move_to_abspath" ]] ; do
                # Generate a new name with a new timestamp, as the previously
                # generated one denoted an existing file.
                move_to_abspath="$trash_dir_abspath/$file_basename-$(date '+%Y-%m-%d-at-%H-%M-%S.%3N')"
            done
            # We're now almost certain that the file denoted by name
            # $move_to_abspath does not exist, as for that to be the case, an
            # extremely unlikely run condition would have had to take place:
            # some other process would have had to create a file with the name
            # $move_to_abspath after the execution of the existence test above.
            # However, to make absolute sure that moving the file to the trash
            # directory will always be successful, we shall give the '-f'
            # (force) flag to the 'mv' command.
            /bin/mv -f "$file_abspath" "$move_to_abspath"
        fi
        echo "moved to trash:   $file_abspath"
    fi
done

5

Rmtrash नाम की एक छोटी सी उपयोगिता है जो ऐसा करती है।

ऐसा प्रतीत नहीं होता है कि यह परमर्स को जवाब देता है -rया -f(यह अनिवार्य रूप से फाइल / डायरेक्टरी को ~ / .Trash डायरेक्टरी में ले जाता है), लेकिन यह एक ही नाम वाली फाइल को ओवरराइड नहीं करेगा (यह "कॉपी" करता है। जैसे नाम वाली फाइलें / निर्देशिकाएं)।

काढ़ा के साथ स्थापित करने के लिए

brew install rmtrash
alias rm='rmtrash' >> ~/.bashrc

github.com/nateshmbhat/rm-trash । "आरएम-कचरा", डुप्लिकेट फ़ाइल नामों और पुनरावर्ती विलोपन को भी संभालता है। इसकी जांच - पड़ताल करें।
नटेश ने

4

यहां एक त्वरित और गंदी कचरा प्रणाली है जो नाम की गड़बड़ी का सामना करती है और यहां तक ​​कि एक ही पथ पर कई हटाई गई फ़ाइलों को अनुमति देती है जब तक कि आप प्रति सेकंड एक से अधिक फ़ाइल नहीं हटाते हैं।

चेतावनी: मैंने इस कोड को सीधे अपने ब्राउज़र में टाइप किया। शायद टूट गया है। उत्पादन डेटा पर इसका उपयोग न करें।

trash_root=~/.trash
mkdir "$trash_root"
newline='
'
trash () (
  time=$(date +%Y%m%d%H%M%S)
  for path; do
    case $path in /*) :;; *) path=$PWD/$path;; esac
    mkdir "$trash_root${path%/*}"
    case ${path##*/} in
      ?*.*) ext="${path##*.}"; ext="${ext##*$newline}";;
      *) ext="";;
    esac
    metadata="Data: $hash.$ext
Date: $time
Path: $path
"
    hash=$(printf %s "$metadata" | sha1sum)
    printf %s "$metadata" "$trash_root/$hash-$time-metadata"
    mv "$path" "$trash_root/$hash.$ext"
  done
)

untrash () (
  IFS='
  '
  root=$PWD
  cd "$trash_root" || return 2
  err=0
  for path; do
    if [ -e "$path" ]; then
      echo 1>&2 "Not even attempting to untrash $path over an existing file"
      if [ $err -gt 2 ]; then err=2; fi
      continue
    fi
    case $path in /*) :;; *) path=$root/$path;; esac 
    if metadata=$(grep -l -F -x "Path: $path" *-metadata |
                  sort -t - -k 2 | tail -n 1); then
      mv "${metadata%%-*}".* "$path"
    else
      echo 1>&2 "$path: no such deleted file"
      if [ $err -gt 1 ]; then err=1; fi
    fi
  done
  return $err
)

ज्ञात पहलु:

  • यदि आप समवर्ती रूप से एक ही फ़ाइल को कई बार हटाने का प्रयास करते हैं, तो आप इनायत का सामना नहीं कर सकते।
  • कचरा निर्देशिका बड़ी हो सकती है, फ़ाइलों को हैश के पहले कुछ अंकों के आधार पर उपनिर्देशिकाओं में भेजा जाना चाहिए।
  • trashफ़ाइल नामों में नई सूचियों के साथ सामना करना चाहिए, लेकिन untrashऐसा नहीं है क्योंकि यह निर्भर करता है grepऔर मेटाडेटा फ़ाइल में newlines बच नहीं रहे हैं।

2

एक move_to_trashफ़ंक्शन को परिभाषित करके प्रारंभ करें :

move_to_trash () {
    mv "$@" ~/.trash
}

उसके बाद उर्फ rm:

alias rm='move_to_trash'

आप हमेशा rmइसे एक बैकस्लैश के साथ बचकर पुराना कह सकते हैं , जैसे \rm:।

मैं नहीं जानता कि रिबूट पर कचरा निर्देशिका को कैसे खाली किया जाए (आपके सिस्टम के आधार पर, आपको rc*स्क्रिप्ट पर ध्यान देना पड़ सकता है ), लेकिन यह एक cronकार्य बनाने के लिए भी सार्थक हो सकता है जो समय-समय पर निर्देशिका को खाली करता है।


2
दुर्भाग्य से, यह आसान हिस्सा था ...: /
कोनराड रूडोल्फ

यह स्क्रिप्ट प्रत्येक फ़ाइल के लिए एक छिपी हुई निर्देशिका में एक पाठ फ़ाइल भी बना सकती है जिसमें वह निर्देशिका है जिसमें एक पुनर्स्थापना स्क्रिप्ट पुरानी स्थान को पढ़ सकती है और उसे वापस ले जा सकती है।
ephsmith

यह भी एक ही नाम के साथ कई हटाए गए फ़ाइलों का खतरा ट्रैश निर्देशिका में टकरा जाएगा, और केवल पिछले एक "हटाए गए" को पुनर्प्राप्त करने में सक्षम होने के लिए जीवित रहेगा।
हत्यारोपी

@ चिल्लर, हाँ। बेशक एक को कमांड के साथ कुछ अतिरिक्त करने की आवश्यकता होगी। जो भी आप चाहते हैं उसे "ट्रैश किए गए" फ़ाइल का नाम दें और मूल पथ रखें: | यह सब चिल्लाता है "पहिया को फिर से क्यों बनाएं"। इस समस्या के मौजूदा समाधान हैं।
इफिथिथ

इसके अलावा, एक अलग उपनाम नाम का उपयोग करें। अपने उपनाम के बिना किसी अन्य मशीन पर काम करें, एक कॉल करें rmऔर वहां आपकी फाइलें जाएं। delएक बेहतर विकल्प हो सकता है।
ग्लेन जैकमैन

1

आप मेरे डेल का उपयोग कर सकते हैं:

http://fex.belwue.de/fstools/del.html

डेल एक -del / उपनिर्देशिका (और पीछे) में फ़ाइलें ले जाता है

उपयोग: डेल [-v] [-यू] फ़ाइल (s)
       डेल [-v] -पी [-आर] [-d दिन] [निर्देशिका]
       डेल [-व] -एल
विकल्प: -v क्रिया मोड
         -u undelete फ़ाइल
         -p पर्स हटाई गई फाइलें [-d दिनों से अधिक पुरानी]
         -r पुनरावर्ती (सभी उपनिर्देशिका)
         -l सूची हटाई गई फ़ाइलें
उदाहरण: del * .tmp # सभी .tmp फ़ाइलें हटाएं
          del -u project.pl # undelete project.pl
          del -vprd 2 # वर्बोज़ पर्ज 2 दिनों से पुरानी फ़ाइलों को हटा दिया गया

0

केडीई 4.14.8 में मैंने फ़ाइलों को रद्दी में ले जाने के लिए निम्न आदेश का उपयोग किया (जैसे कि इसे डॉल्फिन में हटा दिया गया था):

kioclient move path_to_file_or_directory_to_be_removed trash:/

परिशिष्ट I: मैंने कमांड के साथ पाया

    ktrash --help
...
    Note: to move files to the trash, do not use ktrash, but "kioclient move 'url' trash:/"

परिशिष्ट II: फ़ंक्शन (तब इसे अपने .bashrc में स्रोत)

function Rm {
    if [[ "$1" == '--help' ]] ; then
        echo 'USAGE:'
        echo 'Rm --help # - show help'
        echo 'Rm file1 file2 file3 ...'
        echo 'Works for files and directories'
        return
    fi
    for i in "$@" ;
    do
        kioclient move $i trash:/ && echo "$i was trashed"
    done
}
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.