Filter S3 list-objects results to find a key match

2020-02-25 05:17发布

I would like to use the AWS CLI to query the contents of a bucket and see if a particular file exists, but the bucket contains thousands of files. How can I filter the results to only show key names that match a pattern? For example:

aws s3api list-objects --bucket myBucketName --query "Contents[?Key==*mySearchPattern*]"

2条回答
神经病院院长
2楼-- · 2020-02-25 05:34

I tried on Ubuntu 14, awscli 1.2 --query "Contents[?contains(Key,'stati')].Key" --query "Contents[?contains(Key,\'stati\')].Key" --query "Contents[?contains(Key,stati)].Key"

Illegal token value '?contains(Key,'stati')].Key'

After upgraded the aws version to 1.16 , worked with

--query "Contents[?contains(Key,'stati')].Key"

查看更多
Bombasti
3楼-- · 2020-02-25 05:41

The --query argument uses JMESPath expressions. JMESPath has an internal function contains that allows you to search for a string pattern.

This should give the desired results:

aws s3api list-objects --bucket myBucketName --query "Contents[?contains(Key, `mySearchPattern`)]"

(With Linux I needed to use single quotes ' rather than back ticks ` around mySearchPattern.)

If you want to search for keys starting with certain characters, you can also use the --prefix argument:

aws s3api list-objects --bucket myBucketName --prefix "myPrefixToSearchFor"
查看更多
登录 后发表回答