2016-08-03 20:36:28 +00:00
|
|
|
---
|
|
|
|
title: "rclone copy"
|
2021-02-02 13:42:35 +00:00
|
|
|
description: "Copy files from source to dest, skipping already copied."
|
2016-08-03 20:36:28 +00:00
|
|
|
slug: rclone_copy
|
|
|
|
url: /commands/rclone_copy/
|
2020-02-10 12:31:45 +00:00
|
|
|
# autogenerated - DO NOT EDIT, instead edit the source code in cmd/copy/ and as part of making a release run "make commanddocs"
|
2016-08-03 20:36:28 +00:00
|
|
|
---
|
2020-05-22 10:17:37 +00:00
|
|
|
# rclone copy
|
2016-08-03 20:36:28 +00:00
|
|
|
|
2021-02-02 13:42:35 +00:00
|
|
|
Copy files from source to dest, skipping already copied.
|
2016-08-03 20:36:28 +00:00
|
|
|
|
2020-05-22 10:17:37 +00:00
|
|
|
## Synopsis
|
2016-08-03 20:36:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
Copy the source to the destination. Doesn't transfer
|
|
|
|
unchanged files, testing by size and modification time or
|
|
|
|
MD5SUM. Doesn't delete files from the destination.
|
|
|
|
|
2021-10-29 22:30:00 +00:00
|
|
|
Note that when the source is a directory, it is always the contents
|
|
|
|
of the directory that is copied, not the directory itself.
|
2016-08-03 20:36:28 +00:00
|
|
|
|
2021-10-29 22:30:00 +00:00
|
|
|
For example, given the following command:
|
2016-08-03 20:36:28 +00:00
|
|
|
|
|
|
|
rclone copy source:sourcepath dest:destpath
|
|
|
|
|
2021-10-29 22:30:00 +00:00
|
|
|
Let's say there are two files in source:
|
2016-08-03 20:36:28 +00:00
|
|
|
|
|
|
|
sourcepath/one.txt
|
|
|
|
sourcepath/two.txt
|
|
|
|
|
2021-10-29 22:30:00 +00:00
|
|
|
The command will copy them to:
|
2016-08-03 20:36:28 +00:00
|
|
|
|
|
|
|
destpath/one.txt
|
|
|
|
destpath/two.txt
|
|
|
|
|
2021-10-29 22:30:00 +00:00
|
|
|
Not to:
|
2016-08-03 20:36:28 +00:00
|
|
|
|
|
|
|
destpath/sourcepath/one.txt
|
|
|
|
destpath/sourcepath/two.txt
|
|
|
|
|
2021-10-29 22:30:00 +00:00
|
|
|
Also note that the destination is always a directory. If the path
|
|
|
|
does not exist, it will be created as a directory and the contents of
|
|
|
|
the source will be copied into it. This is the case even if the source
|
|
|
|
path points to a file. If you want to copy a single file to a different
|
|
|
|
name you must use [copyto](commands/rclone_copyto/) instead.
|
|
|
|
|
|
|
|
For example, given the command:
|
|
|
|
|
|
|
|
rclone copy source:sourcepath/one.txt dest:destpath/one.txt
|
|
|
|
|
|
|
|
Rclone will create a directory `dest:destpath/one.txt` and put the source file in there:
|
|
|
|
|
|
|
|
dest:destpath/one.txt/one.txt
|
|
|
|
|
|
|
|
Not copy the single source file as a file with the given destination path,
|
|
|
|
which would be the result if copyto had been used instead:
|
|
|
|
|
|
|
|
dest:destpath/one.txt
|
|
|
|
|
2016-08-03 20:36:28 +00:00
|
|
|
If you are familiar with `rsync`, rclone always works as if you had
|
2021-02-02 13:42:35 +00:00
|
|
|
written a trailing `/` - meaning "copy the contents of this directory".
|
2016-08-03 20:36:28 +00:00
|
|
|
This applies to all commands and whether you are talking about the
|
|
|
|
source or destination.
|
|
|
|
|
2019-02-09 10:42:57 +00:00
|
|
|
See the [--no-traverse](/docs/#no-traverse) option for controlling
|
|
|
|
whether rclone lists the destination directory or not. Supplying this
|
|
|
|
option when copying a small number of files into a large destination
|
|
|
|
can speed transfers up greatly.
|
|
|
|
|
|
|
|
For example, if you have many files in /path/to/src but only a few of
|
2020-05-16 14:11:55 +00:00
|
|
|
them change every day, you can copy all the files which have changed
|
|
|
|
recently very efficiently like this:
|
2019-02-09 10:42:57 +00:00
|
|
|
|
|
|
|
rclone copy --max-age 24h --no-traverse /path/to/src remote:
|
|
|
|
|
2020-09-02 15:59:04 +00:00
|
|
|
**Note**: Use the `-P`/`--progress` flag to view real-time transfer statistics.
|
|
|
|
|
|
|
|
**Note**: Use the `--dry-run` or the `--interactive`/`-i` flag to test without copying anything.
|
2018-11-24 13:44:25 +00:00
|
|
|
|
2016-08-03 20:36:28 +00:00
|
|
|
|
|
|
|
```
|
2017-09-30 13:19:47 +00:00
|
|
|
rclone copy source:path dest:path [flags]
|
|
|
|
```
|
|
|
|
|
2020-05-22 10:17:37 +00:00
|
|
|
## Options
|
2017-09-30 13:19:47 +00:00
|
|
|
|
|
|
|
```
|
2019-04-13 10:01:58 +00:00
|
|
|
--create-empty-src-dirs Create empty source dirs on destination after copy
|
|
|
|
-h, --help help for copy
|
2016-08-03 20:36:28 +00:00
|
|
|
```
|
|
|
|
|
2019-06-20 15:18:02 +00:00
|
|
|
See the [global flags page](/flags/) for global options not listed here.
|
|
|
|
|
2020-05-22 10:17:37 +00:00
|
|
|
## SEE ALSO
|
2016-08-03 20:36:28 +00:00
|
|
|
|
2018-10-15 10:03:08 +00:00
|
|
|
* [rclone](/commands/rclone/) - Show help for rclone commands, flags and backends.
|
2018-03-19 10:06:13 +00:00
|
|
|
|