it-swarm.com.de

Linux: Kopieren Sie das Zielverzeichnis und erstellen Sie es, falls es nicht vorhanden ist

Ich möchte einen Befehl (oder wahrscheinlich eine Option für cp), der das Zielverzeichnis erstellt, wenn es nicht vorhanden ist.

Beispiel:

cp -? file /path/to/copy/file/to/is/very/deep/there
279
flybywire
mkdir -p "$d" && cp file "$d"

(Es gibt keine solche Option für cp).

Wenn beide der folgenden Bedingungen zutreffen:

  1. Sie verwenden die GNU Version von cp (und nicht zum Beispiel die Mac-Version) und
  2. Sie kopieren aus einer vorhandenen Verzeichnisstruktur und müssen sie nur neu erstellen

dann kannst du das mit dem --parents Flagge von cp. Auf der Infoseite (einsehbar unter http://www.gnu.org/software/coreutils/manual/html_node/cp-invocation.html#cp-invocation oder mit info cp oder man cp):

--parents
     Form the name of each destination file by appending to the target
     directory a slash and the specified name of the source file.  The
     last argument given to `cp' must be the name of an existing
     directory.  For example, the command:

          cp --parents a/b/c existing_dir

     copies the file `a/b/c' to `existing_dir/a/b/c', creating any
     missing intermediate directories.

Beispiel:

/tmp $ mkdir foo
/tmp $ mkdir foo/foo
/tmp $ touch foo/foo/foo.txt
/tmp $ mkdir bar
/tmp $ cp --parents foo/foo/foo.txt bar
/tmp $ ls bar/foo/foo
foo.txt
210
Paul Whipp

Kurze Antwort

Um myfile.txt Nach /foo/bar/myfile.txt Zu kopieren, verwenden Sie:

mkdir -p /foo/bar && cp myfile.txt $_

Wie funktioniert das?

Es gibt ein paar Komponenten, daher werde ich die gesamte Syntax Schritt für Schritt behandeln.

Das Dienstprogramm mkdir , wie im POSIX-Standard angegeben, erstellt Verzeichnisse. Das Argument -p Führt laut Dokumentation zu mkdir to

Erstellen Sie fehlende Zwischenkomponenten für Pfadnamen

was bedeutet, dass beim Aufruf von mkdir -p /foo/bar mkdir /foo und /foo/bar Falls /foo Noch nicht existiert. (Ohne -p Wird stattdessen ein Fehler ausgegeben.

Der Listenoperator &&, Wie im POSIX-Standard dokumentiert (oder im Bash-Handbuch , wenn Sie es vorziehen), bewirkt, dass cp myfile.txt $_ nur ausgeführt wird, wenn mkdir -p /foo/bar erfolgreich ausgeführt wird. Dies bedeutet, dass der Befehl cp nicht ausgeführt werden kann, wenn mkdir aus einem der vielen Gründe fehlschlägt .

Schließlich ist das $_, Das wir als zweites Argument an cp übergeben, ein "spezieller Parameter", mit dem vermieden werden kann, dass lange Argumente (wie Dateipfade) wiederholt werden, ohne dass sie in einer Variablen gespeichert werden müssen . Gemäß dem Bash-Handbuch gilt Folgendes:

wird bis zum letzten Argument des vorherigen Befehls erweitert

In diesem Fall ist dies das /foo/bar, Das wir an mkdir übergeben haben. Der Befehl cp wird also zu cp myfile.txt /foo/bar Erweitert, wodurch myfile.txt In das neu erstellte Verzeichnis /foo/bar Kopiert wird.

Beachten Sie, dass $_ kein Teil des POSIX-Standards ist, also theoretisch ein Unix Die Variante verfügt möglicherweise über eine Shell, die dieses Konstrukt nicht unterstützt. Allerdings kenne ich keine modernen Shells, die $_ Nicht unterstützen. sicherlich Bash, Dash und Zsh alle tun.


Ein letzter Hinweis: Der Befehl, den ich zu Beginn dieser Antwort gegeben habe, geht davon aus, dass Ihre Verzeichnisnamen keine Leerzeichen enthalten. Wenn Sie mit Namen mit Leerzeichen arbeiten, müssen Sie sie in Anführungszeichen setzen, damit die verschiedenen Wörter verwendet werden werden nicht als andere Argumente als mkdir oder cp behandelt. Ihr Befehl würde also tatsächlich so aussehen:

mkdir -p "/my directory/name with/spaces" && cp "my filename with spaces.txt" "$_"
45
Mark Amery

Solch eine alte Frage, aber vielleicht kann ich eine alternative Lösung vorschlagen.

Sie können das Programm install verwenden, um Ihre Datei zu kopieren und den Zielpfad "on the fly" zu erstellen.

install -D file /path/to/copy/file/to/is/very/deep/there/file

Es sind jedoch einige Aspekte zu berücksichtigen:

  1. sie müssen auch den Zieldateinamen angeben, nicht nur den Zielpfad
  2. die Zieldatei wird ausführbar sein (zumindest soweit ich das von meinen Tests gesehen habe)

Sie können die Nummer 2 ganz einfach ändern, indem Sie das -m Option zum Festlegen von Berechtigungen für die Zieldatei (Beispiel: -m 664 erstellt die Zieldatei mit den Berechtigungen rw-rw-r--, genauso wie beim Erstellen einer neuen Datei mit touch).


Und hier ist das schamloser Link zu der Antwort, die mich inspiriert hat =)

33
help_asap

Shell-Funktion, die das tut, was Sie wollen. Sie nennt es eine "vergrabene" Kopie, weil sie eine Lücke für die Datei gräbt, in der sie leben kann:

bury_copy() { mkdir -p `dirname $2` && cp "$1" "$2"; }
15
Andy Ross

Hier ist eine Möglichkeit, dies zu tun:

mkdir -p `dirname /path/to/copy/file/to/is/very/deep/there` \
   && cp -r file /path/to/copy/file/to/is/very/deep/there

dirname gibt Ihnen das übergeordnete Verzeichnis oder die übergeordnete Datei des Zielverzeichnisses an. mkdir -p `dirname ...` erstellt dann dieses Verzeichnis und stellt sicher, dass beim Aufruf von cp -r das richtige Basisverzeichnis vorhanden ist.

Der Vorteil dieser übergeordneten Elemente ist, dass sie für den Fall funktionieren, dass das letzte Element im Zielpfad ein Dateiname ist.

Und es wird unter OS X funktionieren.

8
Jamie McCrindle

install -D file -m 644 -t /path/to/copy/file/to/is/very/deep/there

5
Spongman

bei allem Respekt für die Antworten oben bevorzuge ich rsync wie folgt:

$  rsync -a directory_name /path_where_to_inject_your_directory/

beispiel:

$ rsync -a test /usr/local/lib/
3
marcdahan

Nur um fortzufahren und eine vollständige funktionierende Lösung in einer Zeile zu geben. Seien Sie vorsichtig, wenn Sie Ihre Datei umbenennen möchten, und geben Sie einen sauberen Verzeichnispfad für mkdir an. $ fdst kann file oder dir sein. Der nächste Code sollte auf jeden Fall funktionieren.

fsrc=/tmp/myfile.unk
fdst=/tmp/dir1/dir2/dir3/myfile.txt
mkdir -p $(dirname ${fdst}) && cp -p ${fsrc} ${fdst}

oder bash spezifisch

fsrc=/tmp/myfile.unk
fdst=/tmp/dir1/dir2/dir3/myfile.txt
mkdir -p ${fdst%/*} && cp -p ${fsrc} ${fdst}
2
Kaalahaan

Das macht es für mich

cp -vaR ./from ./to
2
Leroy Dunn

Fügen Sie einfach Folgendes in Ihre .bashrc-Datei ein, und optimieren Sie sie, falls erforderlich. Funktioniert in Ubuntu.

mkcp() {
    test -d "$2" || mkdir -p "$2"
    cp -r "$1" "$2"
}

Wenn Sie die 'Test'-Datei in das Zielverzeichnis' d 'Use kopieren möchten,

mkcp test a/b/c/d

mkcp prüft zuerst, ob das Zielverzeichnis existiert oder nicht, wenn nicht, mache es und kopiere die Quelldatei/das Quellverzeichnis.

1
SD.

cp hat mehrere Verwendungen:

$ cp --help
Usage: cp [OPTION]... [-T] SOURCE DEST
  or:  cp [OPTION]... SOURCE... DIRECTORY
  or:  cp [OPTION]... -t DIRECTORY SOURCE...
Copy SOURCE to DEST, or multiple SOURCE(s) to DIRECTORY.

@ AndyRoss Antwort funktioniert für die

cp SOURCE DEST

stil von cp, aber macht das Falsche, wenn Sie die

cp SOURCE... DIRECTORY/

stil von cp.

Ich denke, dass "DEST" ohne einen abschließenden Schrägstrich in dieser Verwendung mehrdeutig ist (d. H. Wo das Zielverzeichnis noch nicht existiert), weshalb cp möglicherweise nie eine Option dafür hinzugefügt hat.

Hier ist meine Version dieser Funktion, die einen abschließenden Schrägstrich für das Zielverzeichnis erzwingt:

cp-p() {
  last=${@: -1}

  if [[ $# -ge 2 && "$last" == */ ]] ; then
    # cp SOURCE... DEST/
    mkdir -p "$last" && cp "[email protected]"
  else
    echo "cp-p: (copy, creating parent dirs)"
    echo "cp-p: Usage: cp-p SOURCE... DEST/"
  fi
}
1
Rich

Ich habe ein Unterstützungsskript für cp namens CP (Großbuchstaben beachten) geschrieben, das genau dies tun soll. Das Skript überprüft den Pfad, den Sie eingegeben haben, auf Fehler (mit Ausnahme des letzten Pfads, der das Ziel ist). Wenn alles in Ordnung ist, führt es einen mkdir -p-Schritt aus, um den Zielpfad zu erstellen, bevor die Kopie gestartet wird. Zu diesem Zeitpunkt übernimmt das reguläre Dienstprogramm cp und alle mit CP verwendeten Switches (wie -r, -p, -rpL werden direkt an cp weitergeleitet). Bevor Sie mein Skript verwenden, müssen Sie einige Dinge verstehen.

  • auf alle Informationen hier kann mit CP --help zugegriffen werden. CP --help-all umfasst die cp-Schalter.
  • regular cp kopiert nicht, wenn der Zielpfad nicht gefunden wird. Sie haben kein solches Sicherheitsnetz für Tippfehler mit CP. Ihr Ziel wird erstellt. Wenn Sie Ihr Ziel also als/usrr/share/icons oder/usr/share/icon falsch schreiben, wird genau das erstellt.
  • reguläres cp modelliert sein Verhalten in der Regel auf dem vorhandenen Pfad: cp/a/b/c/d hängt davon ab, ob d vorhanden ist oder nicht. Wenn d ein vorhandener Ordner ist, kopiert cp b in diesen Ordner und erstellt/c/d/b. Wenn d nicht existiert, wird b nach c kopiert und in d umbenannt. Wenn d existiert, aber eine Datei und b eine Datei ist, wird es durch die Kopie von b überschrieben. Wenn c nicht existiert, kopiert cp nicht und beendet das Programm.

CP hat nicht den Luxus, sich an vorhandenen Pfaden zu orientieren, daher muss es einige sehr feste Verhaltensmuster geben. CP geht davon aus, dass das Objekt, das Sie kopieren, im Zielpfad abgelegt wird und nicht das Ziel selbst ist (auch bekannt als umbenannte Kopie der Quelldatei/des Quellordners). Bedeutung:

  • "CP/a/b/c/d" führt zu/c/d/b, wenn d ein Ordner ist
  • "CP/a/b/c/b" führt zu/c/b/b, wenn b in/c/b ein Ordner ist.
  • Wenn sowohl b als auch d Dateien sind: CP/a/b/c/d ergibt/c/d (wobei d eine Kopie von b ist). Gleiches gilt für CP/a/b/c/b unter den gleichen Umständen.

Dieses Standard-CP-Verhalten kann mit dem Schalter "--rename" geändert werden. In diesem Fall wird das angenommen

  • "CP --rename/a/b/c/d" kopiert b nach/c und benennt die Kopie in d um.

Ein paar abschließende Anmerkungen: Wie bei cp kann CP mehrere Elemente gleichzeitig kopieren, wobei der zuletzt aufgeführte Pfad als Ziel angenommen wird. Es kann auch Pfade mit Leerzeichen behandeln, solange Sie Anführungszeichen verwenden.

CP überprüft die von Ihnen eingegebenen Pfade und stellt sicher, dass sie vorhanden sind, bevor Sie den Kopiervorgang ausführen. Im strikten Modus (verfügbar über --strict switch) müssen alle zu kopierenden Dateien/Ordner vorhanden sein oder es findet keine Kopie statt. Im entspannten Modus (--relaxed) wird der Kopiervorgang fortgesetzt, wenn mindestens eines der aufgelisteten Elemente vorhanden ist. Standardmäßig ist der entspannte Modus eingestellt. Sie können den Modus vorübergehend über die Schalter oder dauerhaft ändern, indem Sie die Variable easy_going am Anfang des Skripts festlegen.

So installieren Sie es:

Führen Sie in einem Nicht-Root-Terminal Folgendes aus:

Sudo echo > /usr/bin/CP; Sudo chmod +x /usr/bin/CP; Sudo touch /usr/bin/CP
gedit admin:///usr/bin/CP 

Fügen Sie in gedit das CP-Dienstprogramm ein und speichern Sie:

#!/bin/bash
#Regular cp works with the assumption that the destination path exists and if it doesn't, it will verify that it's parent directory does.

#eg: cp /a/b /c/d will give /c/d/b if folder path /c/d already exists but will give /c/d (where d is renamed copy of b) if /c/d doesn't exists but /c does.

#CP works differently, provided that d in /c/d isn't an existing file, it assumes that you're copying item into a folder path called /c/d and will create it if it doesn't exist. so CP /a/b /c/d will always give /c/d/b unless d is an existing file. If you put the --rename switch, it will assume that you're copying into /c and renaming the singl item you're copying from b to d at the destination. Again, if /c doesn't exist, it will be created. So CP --rename /a/b /c/d will give a /c/d and if there already a folder called /c/d, contents of b will be merged into d. 

#cp+ $source $destination
#mkdir -p /foo/bar && cp myfile "$_"

err=0 # error count
i=0 #item counter, doesn't include destination (starts at 1, ex. item1, item2 etc)
m=0 #cp switch counter (starts at 1, switch 1, switch2, etc)
n=1 # argument counter (aka the arguments inputed into script, those include both switches and items, aka: $1 $2 $3 $4 $5)
count_s=0
count_i=0
easy_going=true #determines how you deal with bad pathes in your copy, true will allow copy to continue provided one of the items being copied exists, false will exit script for one bad path. this setting can also be changed via the custom switches: --strict and --not-strict
verbal="-v"


  help="===============================================================================\
    \n         CREATIVE COPY SCRIPT (CP) -- written by thebunnyrules\
    \n===============================================================================\n
    \n This script (CP, note capital letters) is intended to supplement \
    \n your system's regular cp command (note uncapped letters). \n
    \n Script's function is to check if the destination path exists \
    \n before starting the copy. If it doesn't it will be created.\n    
    \n To make this happen, CP assumes that the item you're copying is \
    \n being dropped in the destination path and is not the destination\
    \n itself (aka, a renamed copy of the source file/folder). Meaning:\n 
    \n * \"CP /a/b /c/d\" will result in /c/d/b \
    \n * even if you write \"CP /a/b /c/b\", CP will create the path /a/b, \
    \n   resulting in /c/b/b. \n
    \n Of course, if /c/b or /c/d are existing files and /a/b is also a\
    \n file, the existing destination file will simply be overwritten. \
    \n This behavior can be changed with the \"--rename\" switch. In this\
    \n case, it's assumed that \"CP --rename /a/b /c/d\" is copying b into /c  \
    \n and renaming the copy to d.\n
    \n===============================================================================\
    \n        CP specific help: Switches and their Usages \
    \n===============================================================================\n
    \
    \n  --rename\tSee above. Ignored if copying more than one item. \n
    \n  --quiet\tCP is verbose by default. This quiets it.\n
    \n  --strict\tIf one+ of your files was not found, CP exits if\
    \n\t\tyou use --rename switch with multiple items, CP \
    \n\t\texits.\n
    \n  --relaxed\tIgnores bad paths unless they're all bad but warns\
    \n\t\tyou about them. Ignores in-appropriate rename switch\
    \n\t\twithout exiting. This is default behavior. You can \
    \n\t\tmake strict the default behavior by editing the \
    \n\t\tCP script and setting: \n
    \n\t\teasy_going=false.\n
    \n  --help-all\tShows help specific to cp (in addition to CP)."

cp_hlp="\n\nRegular cp command's switches will still work when using CP.\
    \nHere is the help out of the original cp command... \
    \n\n===============================================================================\
    \n          cp specific help: \
    \n===============================================================================\n"

outro1="\n******************************************************************************\
    \n******************************************************************************\
    \n******************************************************************************\
    \n        USE THIS SCRIPT WITH CARE, TYPOS WILL GIVE YOU PROBLEMS...\
    \n******************************************************************************\
    \n******************************* HIT q TO EXIT ********************************\
    \n******************************************************************************"


#count and classify arguments that were inputed into script, output help message if needed
while true; do
    eval input="\$$n"
    in_=${input::1}

    if [ -z "$input" -a $n = 1 ]; then input="--help"; fi 

    if [ "$input" = "-h" -o "$input" = "--help" -o "$input" = "-?" -o "$input" = "--help-all" ]; then
        if [ "$input" = "--help-all" ]; then 
            echo -e "$help"$cp_hlp > /tmp/cp.hlp 
            cp --help >> /tmp/cp.hlp
            echo -e "$outro1" >> /tmp/cp.hlp
            cat /tmp/cp.hlp|less
            cat /tmp/cp.hlp
            rm /tmp/cp.hlp
        else
            echo -e "$help" "$outro1"|less
            echo -e "$help" "$outro1"
        fi
        exit
    fi

    if [ -z "$input" ]; then
        count_i=$(expr $count_i - 1 ) # remember, last item is destination and it's not included in cound
        break 
    Elif [ "$in_" = "-" ]; then
        count_s=$(expr $count_s + 1 )
    else
        count_i=$(expr $count_i + 1 )
    fi
    n=$(expr $n + 1)
done

#error condition: no items to copy or no destination
    if [ $count_i -lt 0 ]; then 
            echo "Error: You haven't listed any items for copying. Exiting." # you didn't put any items for copying
    Elif [ $count_i -lt 1 ]; then
            echo "Error: Copying usually involves a destination. Exiting." # you put one item and no destination
    fi

#reset the counter and grab content of arguments, aka: switches and item paths
n=1
while true; do
        eval input="\$$n" #input=$1,$2,$3,etc...
        in_=${input::1} #first letter of $input

        if [ "$in_" = "-" ]; then
            if [ "$input" = "--rename" ]; then 
                rename=true #my custom switches
            Elif [ "$input" = "--strict" ]; then 
                easy_going=false #exit script if even one of the non-destinations item is not found
            Elif [ "$input" = "--relaxed" ]; then 
                easy_going=true #continue script if at least one of the non-destination items is found
            Elif [ "$input" = "--quiet" ]; then 
                verbal=""
            else
                #m=$(expr $m + 1);eval switch$m="$input" #input is a switch, if it's not one of the above, assume it belongs to cp.
                switch_list="$switch_list \"$input\""
            fi                                  
        Elif ! [ -z "$input" ]; then #if it's not a switch and input is not empty, it's a path
                i=$(expr $i + 1)
                if [ ! -f "$input" -a ! -d "$input" -a "$i" -le "$count_i" ]; then 
                    err=$(expr $err + 1 ); error_list="$error_list\npath does not exit: \"b\""
                else
                    if [ "$i" -le "$count_i" ]; then 
                        eval item$i="$input" 
                        item_list="$item_list \"$input\""
                    else
                        destination="$input" #destination is last items entered
                    fi
                fi
        else
            i=0
            m=0
            n=1                     
            break
        fi      
        n=$(expr $n + 1)
done

#error condition: some or all item(s) being copied don't exist. easy_going: continue if at least one item exists, warn about rest, not easy_going: exit.
#echo "err=$err count_i=$count_i"
if [ "$easy_going" != true -a $err -gt 0 -a $err != $count_i ]; then 
    echo "Some of the paths you entered are incorrect. Script is running in strict mode and will therefore exit."
    echo -e "Bad Paths: $err $error_list"
    exit
fi

if [ $err = $count_i ]; then
    echo "ALL THE PATHS you have entered are incorrect! Exiting."
    echo -e "Bad Paths: $err $error_list"
fi

#one item to one destination:
#------------------------------
#assumes that destination is folder, it does't exist, it will create it. (so copying /a/b/c/d/firefox to /e/f/firefox will result in /e/f/firefox/firefox
#if -rename switch is given, will assume that the top element of destination path is the new name for the the item being given.

#multi-item to single destination:
#------------------------------
#assumes destination is a folder, gives error if it exists and it's a file. -rename switch will be ignored.

#ERROR CONDITIONS: 
# - multiple items being sent to a destination and it's a file.
# - if -rename switch was given and multiple items are being copied, rename switch will be ignored (easy_going). if not easy_going, exit.
# - rename option but source is folder, destination is file, exit.
# - rename option but source is file and destination is folder. easy_going: option ignored.

if [ -f "$destination" ]; then
    if [ $count_i -gt 1 ]; then 
        echo "Error: You've selected a single file as a destination and are copying multiple items to it. Exiting."; exit
    Elif [ -d "$item1" ]; then
        echo "Error: Your destination is a file but your source is a folder. Exiting."; exit
    fi
fi
if [ "$rename" = true ]; then
    if [ $count_i -gt 1 ]; then
        if [ $easy_going = true ]; then
            echo "Warning: you choose the rename option but are copying multiple items. Ignoring Rename option. Continuing."
        else
            echo "Error: you choose the rename option but are copying multiple items. Script running in strict mode. Exiting."; exit
        fi
    Elif [ -d "$destination" -a -f "$item1" ]; then
        echo -n "Warning: you choose the rename option but source is a file and destination is a folder with the same name. "
        if [ $easy_going = true ]; then
            echo "Ignoring Rename option. Continuing."
        else
            echo "Script running in strict mode. Exiting."; exit
        fi
    else
        dest_jr=$(dirname "$destination")
        if [ -d "$destination" ]; then item_list="$item1/*";fi
        mkdir -p "$dest_jr"
    fi
else
    mkdir -p "$destination"
fi

eval cp $switch_list $verbal $item_list "$destination"

cp_err="$?"
if [ "$cp_err" != 0 ]; then 
    echo -e "Something went wrong with the copy operation. \nExit Status: $cp_err"
else 
    echo "Copy operation exited with no errors."
fi

exit
1
thebunnyrules

Hatte gerade das gleiche Problem. Mein Ansatz war es, die Dateien einfach wie folgt in ein Archiv zu tarieren:

tar cf your_archive.tar file1 /path/to/file2 path/to/even/deeper/file3

tar speichert die Dateien automatisch in der entsprechenden Struktur im Archiv. Wenn du läufst

tar xf your_archive.tar

die Dateien werden in die gewünschte Verzeichnisstruktur extrahiert.

1
Chris
rsync file /path/to/copy/file/to/is/very/deep/there

Dies könnte funktionieren, wenn Sie die richtige Art von rsync haben.

0
danuker

Wie oben von help_asap und spongeman vorgeschlagen, können Sie den Befehl 'install' verwenden, um Dateien in vorhandene Verzeichnisse zu kopieren oder neue Zielverzeichnisse zu erstellen, falls diese noch nicht vorhanden sind.

Option 1 install -D filename some/deep/directory/filename
kopiert die Datei in ein neues oder vorhandenes Verzeichnis und erteilt den Dateinamen standardmäßig 755 Berechtigungen

Option 2 install -D filename -m640 some/deep/directory/filename
wie Option 1, jedoch mit Dateinamenberechtigung 640.

Option 3 install -D filename -m640 -t some/deep/directory/
Wie Option 2, aber der Dateiname muss in das Zielverzeichnis geschrieben werden, sodass der Dateiname nicht sowohl in die Quelle als auch in das Ziel geschrieben werden muss.

Option 4 install -D filena* -m640 -t some/deep/directory/
wie Option 3, verwendet jedoch einen Platzhalter für mehrere Dateien.

Es funktioniert gut in Ubuntu und kombiniert zwei Schritte (Verzeichniserstellung und Dateikopie) in einem einzigen Schritt.

0
Dig

Einfach

cp -a * /path/to/dst/

sollte den Trick machen.

0
Brad D.

Kopieren Sie von der Quelle in einen nicht vorhandenen Pfad

mkdir –p /destination && cp –r /source/ $_

HINWEIS: Dieser Befehl kopiert alle Dateien

cp –r zum Kopieren aller Ordner und ihres Inhalts

$_ Als Ziel arbeiten, das im letzten Befehl erstellt wurde

0