rclone/docs/content/commands/rclone_lsjson.md

133 lines
5.1 KiB
Markdown
Raw Normal View History

---
title: "rclone lsjson"
description: "List directories and objects in the path in JSON format."
slug: rclone_lsjson
url: /commands/rclone_lsjson/
# autogenerated - DO NOT EDIT, instead edit the source code in cmd/lsjson/ and as part of making a release run "make commanddocs"
---
# rclone lsjson
List directories and objects in the path in JSON format.
## Synopsis
List directories and objects in the path in JSON format.
The output is an array of Items, where each Item looks like this
{
"Hashes" : {
"SHA-1" : "f572d396fae9206628714fb2ce00f72e94f2258f",
"MD5" : "b1946ac92492d2347c6235b4d2611184",
"DropboxHash" : "ecb65bb98f9d905b70458986c39fcbad7715e5f2fcc3b1f07767d7c83e2438cc"
},
2018-06-16 19:21:09 +02:00
"ID": "y2djkhiujf83u33",
2018-09-01 13:58:00 +02:00
"OrigID": "UYOJVTUW00Q1RzTDA",
2019-06-15 13:01:29 +02:00
"IsBucket" : false,
"IsDir" : false,
2018-06-16 19:21:09 +02:00
"MimeType" : "application/octet-stream",
"ModTime" : "2017-05-31T16:15:57.034468261+01:00",
"Name" : "file.txt",
2018-03-19 11:06:13 +01:00
"Encrypted" : "v0qpsdq8anpci8n929v3uu9338",
2019-06-15 13:01:29 +02:00
"EncryptedPath" : "kja9098349023498/v0qpsdq8anpci8n929v3uu9338",
"Path" : "full/path/goes/here/file.txt",
2019-06-15 13:01:29 +02:00
"Size" : 6,
"Tier" : "hot",
}
If --hash is not specified the Hashes property won't be emitted. The
types of hash can be specified with the --hash-type parameter (which
may be repeated). If --hash-type is set then it implies --hash.
If --no-modtime is specified then ModTime will be blank. This can
speed things up on remotes where reading the ModTime takes an extra
2021-02-02 14:42:35 +01:00
request (e.g. s3, swift).
2020-02-01 11:31:42 +01:00
If --no-mimetype is specified then MimeType will be blank. This can
speed things up on remotes where reading the MimeType takes an extra
2021-02-02 14:42:35 +01:00
request (e.g. s3, swift).
2018-03-19 11:06:13 +01:00
If --encrypted is not specified the Encrypted won't be emitted.
If --dirs-only is not specified files in addition to directories are
returned
2019-04-13 12:01:58 +02:00
If --files-only is not specified directories in addition to the files
will be returned.
2019-04-13 12:01:58 +02:00
2021-11-01 16:42:05 +01:00
if --stat is set then a single JSON blob will be returned about the
item pointed to. This will return an error if the item isn't found.
However on bucket based backends (like s3, gcs, b2, azureblob etc) if
the item isn't found it will return an empty directory as it isn't
possible to tell empty directories from missing directories there.
2018-03-19 11:06:13 +01:00
The Path field will only show folders below the remote path being listed.
If "remote:path" contains the file "subfolder/file.txt", the Path for "file.txt"
will be "subfolder/file.txt", not "remote:path/subfolder/file.txt".
When used without --recursive the Path will always be the same as Name.
2022-03-18 13:29:54 +01:00
If the directory is a bucket in a bucket-based backend, then
2019-06-15 13:01:29 +02:00
"IsBucket" will be set to true. This key won't be present unless it is
"true".
2019-02-09 11:42:57 +01:00
The time is in RFC3339 format with up to nanosecond precision. The
number of decimal digits in the seconds will depend on the precision
that the remote can hold the times, so if times are accurate to the
2021-02-02 14:42:35 +01:00
nearest millisecond (e.g. Google Drive) then 3 digits will always be
2019-02-09 11:42:57 +01:00
shown ("2017-05-31T16:15:57.034+01:00") whereas if the times are
2021-02-02 14:42:35 +01:00
accurate to the nearest second (Dropbox, Box, WebDav, etc.) no digits
2019-02-09 11:42:57 +01:00
will be shown ("2017-05-31T16:15:57+01:00").
The whole output can be processed as a JSON blob, or alternatively it
can be processed line by line as each item is written one to a line.
Any of the filtering options can be applied to this command.
2018-03-19 11:06:13 +01:00
There are several related list commands
* `ls` to list size and path of objects only
* `lsl` to list modification time, size and path of objects only
* `lsd` to list directories only
* `lsf` to list objects and directories in easy to parse format
* `lsjson` to list objects and directories in JSON format
2022-03-18 13:29:54 +01:00
`ls`,`lsl`,`lsd` are designed to be human-readable.
`lsf` is designed to be human and machine-readable.
`lsjson` is designed to be machine-readable.
2018-03-19 11:06:13 +01:00
2021-02-02 14:42:35 +01:00
Note that `ls` and `lsl` recurse by default - use `--max-depth 1` to stop the recursion.
2018-03-19 11:06:13 +01:00
2021-02-02 14:42:35 +01:00
The other list commands `lsd`,`lsf`,`lsjson` do not recurse by default - use `-R` to make them recurse.
2018-04-28 12:46:27 +02:00
2022-03-18 13:29:54 +01:00
Listing a non-existent directory will produce an error except for
2021-02-02 14:42:35 +01:00
remotes which can't have empty directories (e.g. s3, swift, or gcs -
2022-03-18 13:29:54 +01:00
the bucket-based remotes).
2018-03-19 11:06:13 +01:00
```
rclone lsjson remote:path [flags]
```
## Options
```
2021-11-01 16:42:05 +01:00
--dirs-only Show only directories in the listing
-M, --encrypted Show the encrypted names
--files-only Show only files in the listing
--hash Include hashes in the output (may take longer)
--hash-type stringArray Show only this hash type (may be repeated)
-h, --help help for lsjson
2021-11-01 16:42:05 +01:00
--no-mimetype Don't read the mime type (can speed things up)
--no-modtime Don't read the modification time (can speed things up)
--original Show the ID of the underlying Object
-R, --recursive Recurse into the listing
--stat Just return the info for the pointed to file
```
See the [global flags page](/flags/) for global options not listed here.
## SEE ALSO
2018-10-15 12:03:08 +02:00
* [rclone](/commands/rclone/) - Show help for rclone commands, flags and backends.
2018-03-19 11:06:13 +01:00