我通过在终端中使用以下命令行将文件从源文件夹复制到目标文件夹。
sudo cp From_SOURCE/* To_DESTINATION/
现在我要撤消此命令。
From_SOURCE/*
,然后从中删除这些文件名To_DESTINATION/
;这可以通过bash来完成-这里的问题可能包括cp命令覆盖了所有内容,复制了符号链接,名称中带有空格的文件等,因此它可能会出现问题并且有点古怪。完美的“撤消”选项可能需要考虑很多东西。
我通过在终端中使用以下命令行将文件从源文件夹复制到目标文件夹。
sudo cp From_SOURCE/* To_DESTINATION/
现在我要撤消此命令。
From_SOURCE/*
,然后从中删除这些文件名To_DESTINATION/
;这可以通过bash来完成-这里的问题可能包括cp命令覆盖了所有内容,复制了符号链接,名称中带有空格的文件等,因此它可能会出现问题并且有点古怪。完美的“撤消”选项可能需要考虑很多东西。
Answers:
如果我了解得很清楚,情况如下:
下面的脚本在原始(源)目录中查找并列出了这些文件。然后,它将查看您将文件复制到的目录,并仅删除列出的文件(如源目录中存在的文件)。
try
添加该元素是为了防止发生错误,例如,如果您可能已经手动删除了一些文件,或者如果不是将源目录中的所有文件都复制到了目标位置,则该元素将被添加。如果需要sudo特权,只需使用“ sudo”运行脚本(请参见下文)。
#!/usr/bin/env python
import os
source_dir = "/path/to/source" # the folder you copied the files from
target_folder = "/path/to/destination" # the folder you copied the files to
for root, dirs, files in os.walk(source_dir):
for name in files:
try:
os.remove(target_folder+"/"+name)
except FileNotFoundError:
pass
reverse.py
,通过以下命令运行它:
[sudo] /path/to/reverse.py
如果我很了解您需要实现的目标,请首先尝试测试目录!
如果源目录没有子目录,则脚本甚至可以更简单:
#!/usr/bin/env python
import os
source_dir = "/path/to/source" # the folder you copied the files from
target_folder = "/path/to/destination" # the folder you copied the files to
for file in os.listdir(source_dir):
try:
os.remove(target_folder+"/"+file)
except FileNotFoundError:
pass
注意
如果复制操作在目标位置重写(替换)了一个名称相似的文件,则该文件将被删除,但脚本将不会带回原始文件(当然)。假设没有名称冲突。
sudo python3 reverse.py
。我接受你的回答。
cp
。
cp -r
。我换os.remove
用print
,它的输出一堆不存在的文件。我假设它缺少子目录,而只在最后列出文件。
是存在于所有文件src
,并dest
可以从被删除dest
这样的:
find . -maxdepth 1 -type f -exec cmp -s '{}' "$destdir/{}" \; -exec mv -n "$destdir/{}" "$toDelete"/ \;
有关分步说明,请参见下文。
要了解我们要撤消的命令实际执行的操作,我们首先将其简化:
我们要撤消的命令是
sudo cp From_SOURCE/* To_DESTINATION/
对于了解如何撤消,sudo
无关紧要。
我将使用的目录名称src
为From_SOURCE
和dest
的To_DESTINATION
。
现在,我们的命令是:
cp src/* dest/
如果src
包含文件f1
,f2
和f3
以及目录d1
和d2
,则外壳程序会将命令扩展为:
cp src/f1 src/f2 src/f3 src/d1 src/d2 dest/
如果没有选择喜欢的-r
,-R
或者-a
,该命令cp
不复制目录。
这意味着,该命令将忽略它们,并为每个显示错误:
$ cp src/f1 src/f2 src/f3 src/d1 src/d2 dest/
cp: omitting directory 'src/d1'
cp: omitting directory 'src/d2'
这就是说,我们仅将简单文件复制而没有目录复制到dest
。
可能存在与中的文件dest
同名的文件src
。在这种情况下,文件将被覆盖(1)。对他们来说为时已晚,对不起。从最新备份中找回它们。
关于其中的文件,我们只想删除已复制的文件。这些文件存在于两个目录中,具有相同的名称和相同的内容。
因此,我们寻找以下文件:
首先,我们cd
进入src
,因为它使以下find
命令更加简单,并将变量设置为dest的绝对路径:
$ cd src
$ destdir="$(readlink -f dest)"
然后,我们列出src中的所有文件:
$ find . -maxdepth 1 -type f
对于找到的每个文件,使用cmp
检查dest中是否存在具有相同内容的文件:
$ find . -maxdepth 1 -type f -exec cmp -s '{}' "$destdir/{}" \; -print
这些文件是我们要删除的文件。但是可以肯定的是,我们首先将它们移动到另一个目录中,然后在运行它们之前先看一下命令:
$ toDelete=/tmp/toDelete ; mkdir -p "$toDelete"
$ find . -maxdepth 1 -type f -exec cmp -s '{}' "$destdir/{}" \; -exec echo mv -n "$destdir/{}" "$toDelete"/ \;
mv -n /path/to/dest/./f1 /tmp/toDelete/`
mv -n /path/to/dest/./f2 /tmp/toDelete/`
mv -n /path/to/dest/./f3 /tmp/toDelete/`
看起来不错!现在我们可以省略echo
运行实际的mv
命令了:
find . -maxdepth 1 -type f -exec cmp -s '{}' "$destdir/{}" \; -exec mv -n "$destdir/{}" "$toDelete"/ \;
所有的文件dest
,从被复制src
,而实际上仍然在同src
和dest
,现在是/tmp/toDelete/
,并且可以在拍摄最后一眼后,被删除。
注意:
(1)检查是否cp
为别名cp -i
,是否可以通过先询问来防止覆盖文件。
这很旧,但是我只想发布一个纯bash答案:
首先转到复制文件的目录。
cd dest
然后,ls
在源目录中将输出通过管道传递到rm
ls source | xargs rm
ls
通常是一个坏主意。mywiki.wooledge.org/ParsingLs 我不会拒绝您的文章,但必须注意。